先看这样一些测试代码,我们能从当中发现哪些问题:
var str=”likeke”;
str;//”likeke”
str.length;//6
str.age=22;
str.age;//undefined;
var mystr=new String(“likeke”);
mystr;//String {0: "l", 1: "i", 2: "k", 3: "e", 4: "k", 5: "e", length: 6, [[PrimitiveValue]]: "likeke"}
mystr.length;//6
mystr.age=22;
mystr.age;//22
第一个问题:为什么基本类型string可以访问到length属性?
第二个问题:string的包装类型可以访问到自定义的属性,但基本类型的string为什么却访问不到?
原因:1.当我们以对象的形式访问一个基本类型string的属性或为其创建新属性的时候,js引擎会将其转换为对应的包装类型对象;
2.当我们增加一个自定义属性之后,这个临时对象会被立即销毁。因此,再次访问此属性时(也会再次转换为其包装类型)显示为undefind 。
除了string之外,其它基本类型也是类似的原理,例如,(666).toString().length;//3