JavaScript权威指南学习笔记(二)
接上篇 第三章
5、全局对象
全局对象是js解释器初始化供全局使用的对象。每次加载新页面时都会创建一个新的全局对象,可以使用this来引用全局对象。程序中可以直接使用全局对象的属性。
6、包装对象
在使用基本类型的属性时创建的临时对象。它是一种实现,和Java中的装箱拆箱机制相似。
和普通对象的区别在于生存期,包装对象的生存期只是一瞬间。
var str = 'hello'; //string 基本类型 var s2 = str.charAt(0); //在执行到这一句的时候 后台会自动完成以下动作 : ( var str = new String('hello'); // 1 找到对应的包装对象类型,然后通过包装对象创建出一个和基本类型值相同的对象 var s2 = str.chaAt(0); // 2 然后这个对象就可以调用包装对象下的方法,并且返回结给s2. str = null; // 3 之后这个临时创建的对象就被销毁了, str =null; ) alert(s2);//h alert(str);//hello 注意这是一瞬间的动作 实际上我们没有改变字符串本身的值。就是做了下面的动作.这也是为什么每个字符串具有的方法并没有改变字符串本身的原因。
var str = 'hello'; str.number = 10; //假设我们想给字符串添加一个属性number ,后台会有如下步骤 { var str = new String('hello'); // 1 找到对应的包装对象类型,然后通过包装对象创建出一个和基本类型值相同的对象 str.number = 10; // 2 通过这个对象调用包装对象下的方法 但结果并没有被任何东西保存 str =null; // 3 这个对象又被销毁 } alert(str.number); //undefined 当执行到这一句的时候,因为基本类型本来没有属性,后台又会重新重复上面的步骤 { var str = new String('hello'); // 1 找到基本包装对象,然后又新开辟一个内存,创建一个值为hello对象 str.number = undefined // 2 因为包装对象下面没有number这个属性,所以又会重新添加,因为没有值,所以值是未定 ;然后弹出结果 str =null; // 3 这个对象又被销毁 }
由于包装对象的生存期只是一瞬间,所以无法直接添加属性,只能通过为包装对象的原型创建方法和属性。
//给字符串添加方法 要写到对应的包装对象的原型下才行 var str = 'hello'; String.prototype.last= fuction(){ return this.charAt(this.length); }; str.last(); // 5 执行到这一句,后台依然会偷偷的干这些事 { var str = new String('hello');// 找到基本包装对象,new一个和字符串值相同的对象, str.last(); // 通过这个对象找到了包装对象下的方法并调用 str =null; // 这个对象被销毁 }
7、类型转换