js中 基本包装类型

为了便于操作基本类型,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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值