基本的数据类型有:`undefined,boolean,number,string,null.基本类型的访问是按值访问的,就是说你可以操作保存在变量中的实际的值。
基本类型有以下几个特点:
(1)基本类型的值是不可变类型,我们不能给基本类型添加属性和方法。
var name = 'hello';
name.toUpperCase(); // 输出 'HELLO'
console.log(name); // 输出 'hello'
会发现原始的name并未发生改变,而是调用了toUpperCase()方法后返回的是一个新的字符串。
var person = 'hello';
person.age = 22;
person.method = function(){//...};
console.log(person.age); // undefined
console.log(person.method); // undefined
(2)基本类型的比较是值的比较
var a = 1;
var b = true;
console.log(a == b);//true
在用==比较两个不同类型的变量时会进行一些类型转换。
像上面的比较先会把true转换为数字1再和数字1进行比较,结果就是true。
这是当比较的两个值的类型不同的时候==运算符会进行类型转换,
但是当两个值的类型相同的时候,即使是==也相当于是===。
var a = 'hello';
var b = 'hello';
console.log(a === b);//true
(3)基本类型的变量是存放在栈区的(栈区指内存里的栈内存),栈区包括了 变量的标识符和变量的值
(4)基本类型在赋值操作后,两个变量是相互不受影响
var a = 10;
var b = a;
a ++ ;
console.log(a); // 11
console.log(b); // 10
a中保存的值为 10 ,当使用 a 来初始化 b 时,b 中保存的值也为10,但b中的10与a中的是完全独立的,该值只是a中的值的一个副本,此后,
这两个变量可以参加任何操作而相互不受影响。
引用类型,
对象是属性和方法的集合。
也就是说引用类型可以拥有属性和方法,属性又可以包含基本类型和引用类型。来看看引用类型的一些特性:
(1)可为为引用类型添加属性和方法,也可以删除其属性和方法,因此引用类型可以拥有属性和方法,并且是可以动态改变的
(2)引用类型的值是同时保存在栈内存和堆内存中的对象
javascript和其他语言不同,其不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间,那我们操作啥呢? 实际上,是操作对象的引用,
所以引用类型的值是按引用访问的。
准确地说,引用类型的存储需要内存的栈区和堆区(堆区是指内存里的堆内存)共同完成,栈区内存保存变量标识符和指向堆内存中该对象的指针,
也可以说是该对象在堆内存的地址。
(3)引用类型的比较是引用的比较
var person1 = {};
var person2 = {};
console.log(person1 == person2); // false
引用类型时按引用访问的,换句话说就是比较两个对象的堆内存中的地址是否相同,那很明显,person1和person2在堆内存中地址是不同的
(4)对象引用,任何的操作都会相互影响
引用类型的赋值其实是对象保存在栈区地址指针的赋值,因此两个变量指向同一个对象,任何的操作都会相互影响
当从一个变量向另一个变量赋值引用类型的值时,同样也会将存储在变量中的对象的值复制一份放到为新变量分配的空间中。前面讲引用类型的时候提到,
保存在变量中的是对象在堆内存中的地址,所以,与简单赋值不同,这个值的副本实际上是一个指针,而这个指针指向存储在堆内存的一个对象。那么赋值操作后,
两个变量都保存了同一个对象地址,则这两个变量指向了同一个对象。因此,改变其中任何一个变量,都会相互影响。
var a = {}; // a保存了一个空对象的实例
var b = a; // a和b都指向了这个空对象
a.name = 'hello';
console.log(a.name); // 'hello'
console.log(b.name); // 'hello'
b.age = 22;
console.log(b.age);// 22
console.log(a.age);// 22
console.log(a == b);// true