为了便于操作基本类型,ECMAScript还提供了3个特殊的引用类型Boolean、Number、String。这些类型与其他引用类型形似,但同时也具有各自的基本类型相应的特殊行为。实际上,每当读取一个基本类型值时后台就会创建一个相应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据。
eg: var str1 = "abcs";
var str2 = str1.concat();
//str1包含一个字符串,字符串是基本类型值。基本类型值不是对象,因而从逻辑上将它们不应该有方法,但它们确实有方法。后台已经自动完成了一系列的处理,当访问str1时后台会自动进行如下处理:
(1)创建String类型的一个实例
var str1=new String("abcs");
(2)在实例上调用指定方法
var str2=str1.concat()
(3)销毁这个实例
str1=null;
//经过这些处理,基本的字符串值就变跟对象一样了,Boolean、Number同理
注意:
* 使用new创建的引用类型的实例,在执行流离开当前作用域之前一直保存在内存中,而自动创建的基本包装类型的对象,则只存在于一行代码的瞬间,然而立即销毁。这意味着不能在运行时为基本类型值添加属性和方法。
var str1 = "123";
str1.name="字符串";
console.log(str1.name);//undefined
* 可以显示地调用Boolean、Number、String来创建基本包装类型的对象。不过,应该在绝对必要的情况下再这么做,因为这样做让人分不清自己是在处理基本类型还是引用类型的值。
* 对基本包装类型的实例调用typeof会返回“object”,而且所有基本包装类型的对象都会被转换为布尔值true.
var obj = new Number(value);
console.log(typeof obj);//"object"
var obj = Number(value);
alert(obj);//"number"
* Object构造函数也会像工厂方法一样,根据传入值的类型返回相应包装类型的实例
var obj = new Object("abc");
console.log(obj instaceof String);//true
eg: var str1 = "abcs";
var str2 = str1.concat();
//str1包含一个字符串,字符串是基本类型值。基本类型值不是对象,因而从逻辑上将它们不应该有方法,但它们确实有方法。后台已经自动完成了一系列的处理,当访问str1时后台会自动进行如下处理:
(1)创建String类型的一个实例
var str1=new String("abcs");
(2)在实例上调用指定方法
var str2=str1.concat()
(3)销毁这个实例
str1=null;
//经过这些处理,基本的字符串值就变跟对象一样了,Boolean、Number同理
注意:
* 使用new创建的引用类型的实例,在执行流离开当前作用域之前一直保存在内存中,而自动创建的基本包装类型的对象,则只存在于一行代码的瞬间,然而立即销毁。这意味着不能在运行时为基本类型值添加属性和方法。
var str1 = "123";
str1.name="字符串";
console.log(str1.name);//undefined
* 可以显示地调用Boolean、Number、String来创建基本包装类型的对象。不过,应该在绝对必要的情况下再这么做,因为这样做让人分不清自己是在处理基本类型还是引用类型的值。
* 对基本包装类型的实例调用typeof会返回“object”,而且所有基本包装类型的对象都会被转换为布尔值true.
var obj = new Number(value);
console.log(typeof obj);//"object"
var obj = Number(value);
alert(obj);//"number"
* Object构造函数也会像工厂方法一样,根据传入值的类型返回相应包装类型的实例
var obj = new Object("abc");
console.log(obj instaceof String);//true