一:基本类型
基本类型有:undefind boolean number string null.
基本类型的访问是按值访问的,就是说,可以操作保存在变量中的实际的值。
1 基本类型的值是不可变得:
任何方法都无法改变一个基本类型的值
例:var name = 'jozo';
name.toUpperCase(); // 输出 'JOZO'
console.log(name); // 输出 'jozo'
原始的name并未发生改变,而是调用toUpperCase()方法后返回一个新的 字符串
var person = 'jozo';
person.age = 22;
person.method = function(){//...};
console.log(person.age); // undefined
console.log(person.method); // undefined
可以看出,我们不能给基本类型添加属性和方法。(基本类型值不可变)
2 基本类型的比较是值的比较
例:var a = 'jozo';
var b = 'jozo';
console.log(a === b);//true
3 基本类型的变量是存放在栈区的(栈区指向内存里的栈内存)
栈区包括了变量的标识符和变量的值
例:var name = 'jozo';
var city = 'guangzhou';
var age = 22;
栈区就是:name jozo
city guangzhou
age 22
引用类型
javascript中除了上面的基本类型(number,string,boolean,null,undefined)之外就是引用类型了,也可以说是就是对象了。对象是属性和方法的集合。
也就是说引用类型可以拥有属性和方法,属性又可以包含基本类型和引用类型。来看看引用类型的一些特性:
1 引用类型的值是可变的
我们可以为引入类型添加属性和方法,也可以删除属性方法,
例:var person = {};//创建个控对象 --引用类型
person.name = 'jozo';
person.age = 22;
person.sayName = function(){console.log(person.name);}
person.sayName();// 'jozo'
delete person.name; //删除person对象的name属性
person.sayName(); // undefined
2 引用类型的值是同时保存在栈内存和堆内存中的对象
javascript,不允许直接访问内存中的位置,也就是不能直接操作对象 的内存空间。
方法:操作对象的引用,所以,引用类型的值,是按引用访问的。
(引用类型的存储要内存的栈区和堆区共同完成的。栈区保存变量标识符和指向对内存中该对象是指针,就是该对象在堆内存的地址。)
3:引用类型的比较是引用的比较(即内存地址比较)
例:基本类型比较
var person1 = '{}';
var person2 = '{}';
console.log(person1 == person2); // true
引入类型比较
var person1 = {};
var person2 = {};
console.log(person1 == person2); // false
因为引用类型按引用访问,就是按两个对象内存中的地址。person1和person2在堆内存中地址是不同的,所以是false.
简单赋值
在从一个变量向另一个变量赋值基本类型时,会在该变量上创建一个新值,然后再把该值赋值到新变量分配的位置上。
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中的值的一 个副本,此后,
这两个变量可以参加任何操作而相互不受影响。
也就是说基本类型在赋值操作后,两个变量是相互不受影响的。
对象引用
当从一个变量向另一个变量赋值引用类型的值时,同样也会将存储在变量中的对象的值复制一份放到为新变量分配的空间中。
因为引用类型保存在变量中的是对象在堆内存中的地址。
而这个指针指向存储在堆内存的一个对象。那么赋值操作后,
两个变量都保存了同一个对象地址,则这两个变量指向了同一个对象。因此,改变其中任何一个变量,都会相互影响:
var a = {}; // a保存了一个空对象的实例
var b = a; // a和b都指向了这个空对象
a.name = 'jozo';
console.log(a.name); // 'jozo'
console.log(b.name); // 'jozo'
b.age = 22;
console.log(b.age);// 22
console.log(a.age);// 22
console.log(a == b);// true