基本类型和引用类型
ECMAScript变量可能包含两种不同数据类型的值:基本类型值和引用类型值。
基本数据类型有:undefined,null,boolean,string,number;这五种基本类型是按值访问的,因为可以操作保存在变量中的实际的值。
引用类型为Object,引用类型的值是保存在内存中的对象。
基本数据类型和引用类型的区别有以下几种:
1、动态的属性
引用类型可以在上面保存或删改需要的属性,例如:
var obj = {}
obj.name = '小明'
console.log(obj.name) // '小明'
基础数据类型就是一个单纯的值,无法操作其属性,例如:
var str = '小明'
str.age = 18
console.log(str.age) // undefined
注意,这里并不是没有为str添加age属性,而是JavaScript在为str添加属性之后又马上删除了这个属性(具体可以看高程的5.6节—基本包装类型)
2、复制变量值
基本类型值在复制的时候,会在变量对象上直接创建一个新值,然把该值复制到为新变量分配的位置上,例如:
var a = 10
var b = a
a = 20
console.log(a) // 20
console.log(b) // 10
基本类型值被复制后,两个值是独立的,相互之间不会干扰
引用类型值在复制的时候,和基本类型值一样,也是在变量对象上直接创建一个新值,然把该值复制到为新变量分配的位置上,但区别在于,引用类型值复制的并不是一个具体的值,而是一个指针,指向存储在堆中的一个对象。所以在复制结束后,两个变量的值实际上就是同一个东西。例如:
var obj = {name: '小明'}
var obj2 = obj
var obj3 = {name: '小明'}
console.log(obj2) // {name: '小明'}
console.log(obj === obj2) // true
console.log(obj === obj3) // false
1、在复制前,obj的值是一个内存地址,指向内存中存在的一个object;
2、使用obj2复制了obj之后,并不是新生成一个和obj一样的对象,而是复制了obj的内存地址,所以obj和obj2是指向同一块内存区域;
3、当创建一个和obj内容一样的obj3的时候,javascript为obj3创建出一块新的内存区域,obj3就指向这个新的内存区域;