一 Js基本数据类型以及内存情况
1 Undefined
Undefined类型只有一个值undefined,在使用了声明但未初始化的变量的时候,这个变量值就是undefined
1 var hi;
2 alert(hi);//undefined
2 Null
Null类型也只有一个值null,可以把null理解为一个空指针。
3 Boolean
Boolean只有两个字面值true和false。
4 Number
就是其他语言里的整数和浮点数。
5 String
就是字符序列,可以用单引号或双引号表示
1 var a =’hi’;
2 var b = “hi”;
以上5种类型在内存中占有固定大小的空间,它们的值保存在栈内存中。
6 Object
Object类型是其他所有实例的基础。
对于引用类型的值,是在堆内存中分配空间。但由于内存地址大小是固定的,因此内存地址保存在栈内存中,所以查询的时候先从栈内存中取到地址,然后在通过地址找到堆内存中的实际值。
二 变量的复制
基本类型:会在栈上创建一个新的值,然后把该值复制到新变量的位置上。
1 var a = 1;
2 var b = a;
a和b都是1,操作不会相互影响
引用类型:会将对象复制一份到新分配的变量中,但复制的是指针,而这个指针指向堆中的同一个对象。
1 var a = new object();
2 var b = a;
3 a.name = “hi”;
4 alert(b.name);
三 作用域链
1 function内定义的变量是局部变量,是作用域链的里层。作用域链是由内向外查找的,找到则停止搜索
2 没有自己的块级作用域(指的是由花括号封闭的代码块),如if for语句
3 不加关键字var 声明的变量是全局变量,当使用var关键字声明变量时,这个变量将被添加到最近的作用域中。
四 面向对象
Javascript中没有类的概念,所以创建对象的方式和其他语言也有很大区别。
1. 简单对象创建
1 //创建对象
2 var cat = new Object();
3 //属性
4 cat.name = "tom";
5 cat.sex = "boy";
6 cat.age = 16;
7 //方法
8 cat.sayName = function() {
9 alert(this.name);
10 }
11 cat.sayName();
2. 构造函数模式
1 function Cat(name, sex, age) {
2 this.name = name
3 this.sex = sex
4 this.age = age
5 this.sayName = function() {
6 alert(this.name);
7 }
8 }
9
10 var cat = new Cat("tom", "boy", 16);
11 cat.sayName();
3. 结合构造函数和原型模式
prototype属性
通俗的理解是它可以让所有对象的实例共享它所包含的属性和方法。
构造函数用于定义实例属性,原型模式用于定义共享属性和方法。
1 function Cat(name, sex, age) {
2 //定义实例属性
3 this.name = name;
4 this.sex = sex;
5 this.age = age;
6 }
7
8 Cat.prototype = {
9 //共享属性和方法
10 canCatchMouse:true,
11 sayName: function() {
12 alert(this.name);
13 }
14 }
15
16 var whiteCat = new Cat("tom", "boy", 16);
17 var blackCat = new Cat("lily", "girl", 13);
18
19 alert(whiteCat.name == blackCat.name);//false
20 alert(whiteCat.canCatchMouse == blackCat.canCatchMouse);//true