简介
(1)为了便于操作基本类型值,ECMAScript 还提供了 3 个特殊的引用类型:Boolean、Number 和 String
(2)这些类型与其他引用类型相似,但同时也具有与各自的基本类型相应的特殊行为
(3)每当读取一个基本类型值的时候,后台就会创建一个对应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据
原理
实例一
var s1 = "some text";
var s2 = s1.substring(2);
分析
1、基本类型值不是对象,因而从逻辑上讲它们不应该有方法,其实,为了让我们实现这种直观的操作, 后台已经自动完成了一系列的处理
2、当第二行代码访问 s1 时,访问过程处于一种读取模式,也就是要从内存中读取这个字符串的值。而在读取模式中访问字符串时,后台都会自动完成下列处理
(1) 创建 String 类型的一个实例
(2) 在实例上调用指定的方法
(3) 销毁这个实例
可以将以上三个步骤想象成是执行了下列 ECMAScript 代码:
var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;
实例二
var s1 = "some text";
s1.color = "red";
alert(s1.color); //undefined
分析
区别
引用类型与基本包装类型的主要区别就是对象的生存期
(1)使用 new 操作符创建的引用类型的实例, 在执行流离开当前作用域之前都一直保存在内存中
(2)而自动创建的基本包装类型的对象,则只存在于一行代码的执行瞬间,然后立即被销毁,所以不能在运行时为基本类型值添加属性和方法
实例三
var obj = new Object("some text");
alert(obj instanceof String); //true
分析
Object 构造函数也会像工厂方法一样,根据传入值的类型返回相应基本包装类型的实例
实例四
var value = "25";
var number = Number(value); //转型函数
alert(typeof number); //"number"
var obj = new Number(value); //构造函数
alert(typeof obj); //"object"
分析
使用 new 调用基本包装类型的构造函数,与直接调用同名的转型函数是不一样的。在这个例子中,变量 number 中保存的是基本类型的值 25,而变量 obj 中保存的是 Number 的实例
总结
1、基本包装类型其他引用类型相似,但同时也具有与各自的基本类型相应的特殊行为
2、每当读取一个基本类型值的时候,后台就会创建一个对应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据
3、引用类型与基本包装类型的主要区别就是对象的生存期
(1)使用 new 操作符创建的引用类型的实例, 在执行流离开当前作用域之前都一直保存在内存中
(2)而自动创建的基本包装类型的对象,则只存在于一行代码的执行瞬间,然后立即被销毁
4、Object 构造函数也会像工厂方法一样,根据传入值的类型返回相应基本包装类型的实例
5、使用 new 调用基本包装类型的构造函数,与直接调用同名的转型函数是不一样的
6、可以显式地调用 Boolean、Number 和 String 来创建基本包装类型的对象。不过,应该在绝对必要的情况下再这样做,因为这种做法很容易让人分不清自己是在处理基本类型还是引用类型的值
参考
《JavaScript高级程序设计(第3版)》