JavaScript

JavaScrpit笔记


数据类型

ECMAScript中有5种简单数据类型(也称为基本数据类型):Undefined、Null、Boolean、Number和String。还有1种复杂数据类型——Object,Object本质上是由一组无序的名值对组成的。

ECMAScript的变量是松散类型的,所谓松散类型就是可以用来保存任何类型的数据
例如:

 var age = 12;//不用int修饰 

typeof运算符

虽然变量无类型之分 但其值是有类型的 用typeof运算符判断

    "undefined"——如果这个值未定义;
    "boolean"——如果这个值是布尔值;
    "string"——如果这个值是字符串;
    "number"——如果这个值是数值;
    "object"——如果这个值是对象或null;
    "function"——如果这个值是函数

undenfined类型 和 null类型\

undefined值是派生自null值的

alert(undefined == null) // true

一般的把var 定义的没有初始化的值定义为 undefined 而null是用来初始化未赋值的对象的。

Boolean类型

注:Boolean类型的字面量的值区分大小写。 true和flase 对 True和Flase 错

NUmber类型

NaN(NOt a NUmber)例如:

 var num = 10/0

String类型

string 是存储在栈中 所以字符串一旦创建就不能改变

Object类型

函数

JS中的函数也是对象 也有相应的属性和方法

属性:length(argument数组的长度)和prototype(继承和原型构造函数时特别有用)

方法:call()和apply() 用来扩大作用域 (可以借用父类的构造函数 和原型链一起构成组合继承)


定义函数

  1. 函数声明

     function functionName(){ // 函数体}
    
  2. 函数表达式

     var sayHi = function(){// 函数体} //函数是对象的体现 
     有一个特别好玩的功能:模仿块级作用域
     (function(){ 
     
     //for(var i ...)
     })()  //i在for循环有用
    

模拟重载

JS中没有重载的概念 但可以用 arguments对象来模拟重载
例如:

//变相实现重载
function add(){

    if(arguments.length == 1){
    
      alert(argumemts[0]+10);
    }

    if(arguments.length == 2){
    
      alert(argumemts[0]+argument[1]+10);
    }

}
add(10);
add(10,20);

继承和创造对象

理解prototype属性:

无论什么时候,只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象。在默认情况下,所有原型对象都会自动获得一个constructor(构造函数)属性,这个属性包含一个指向prototype属性所在函数的指针。就拿前面的例子来说,Person.prototype. constructor指向Person。而通过这个构造函数,我们还可继续为原型对象添加其他属性和方法。

通过prototype属性指向的原型对象 创建的对象

function Person(){

    Person.prototype.name = "Nicholas";
    Person.prototype.age = 29;
    Person.prototype.job = "Software Engineer";
    Person.prototype.sayName = function(){
        alert(this.name);
    };
}

var person1 = new Person();
person1.sayName();   //"Nicholas"
var person2 = new Person();
person2.sayName();   //"Nicholas"
alert(person1.sayName == person2.sayName);  //true

而通过构造函数创建的对象 每个对象的属性和方法在内存中各有一份 其中一个对象的改变不影响其他对象的属性和方法(prototype定义的对象则不同)

继承就是把prototype属性指向的原型对象 进行重写

function SuperType(){
    this.property = true;
}

SuperType.prototype.getSuperValue = function(){
    return this.property;
};

function SubType(){
    this.subproperty = false;
}

//继承了SuperType
SubType.prototype = new SuperType(); // 重写SubType.prototype指向的原型对象

SubType.prototype.getSubValue = function (){
    return this.subproperty;
};



var instance = new SubType();
alert(instance.getSuperValue());      //true

总结:其实创建对象和继承还有很多的方式 可以参考JavaScript高级程序设计(第3版)


闭包(函数和函数非不清的关系)

js闭包的来源:return函数名或者匿名函数 ②函数可以嵌套函数

形式:闭包就是一个函数,两个函数彼此嵌套,内部函数就是闭包(需要return)

          function f1(){
                var age = 20;
                var height = 170;
                function f2(){
                    console.log("年龄:"+age+"-身高:"+height);
                }
                return f2;
            }
            //ff--> 函数名
            var ff = f1();  
            ff();//年龄:20-身高:170
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容