【03】包装对象
【01】字符串具有属性和方法:
let s = "hello world!"; // 一个字符串
let word = s.substring(s.indexOf(" ")+1, s.length); //使用字符串的属性
字符串不是对象,为什么会有属性?
因为引用字符串的属性时,JS会将字符串值通过调用new String()的方式转换成对象,这个对象继承了字符串的方法,并被用来处理属性的引用。
一旦属性引用结束,这个新创建的对象就会被销毁(其实在实现上并不一定创建或销毁这个临时对象,然而整个过程看起来是这样的)。
【02】同字符串一样,数字和布尔值也具有各自的方法:
通过Number()和Boolean()构造函数创建一个临时对象,这些方法的调用均是来自于这个临时对象(包装对象)。
null和undefined没有包装对象:访问它们的属性会报一个类型错误。
【03】代码:
let s = "test"; //创建一个字符串
s.len = 4; // 给它设置一个属性
let t = s.len; // 查询这个属性
当运行这段代码时,t的值是undefined。
第二行代码创建一个临时字符串对象,并给其len属性赋值为4,随即销毁这个对象。
第三行通过原始的(没有被修改过)字符串值创建一个新字符串对象,尝试读取其len属性,这个属性自然不存在,表达式求值结果为undefined。
这段代码说明了在读取字符串、数字和布尔值的属性值(或方法)的时候,表现的像对象一样。
但是,给字面量字符串设置属性时,会忽略这个操作:修改只是发生在临时对象身上,而这个临时对象并不会保留下来。
读取字符串、数字或布尔值的属性时创建的临时对象称做包装对象,它只是偶尔用来区分字符串值和字符串对象、数字和数值对象以及布尔值和布尔对象。
通常,包装对象只是被看做是一种实现细节,而不用特别关注。
由于字符串、数字和布尔值的属性都是只读的,并且不能给它们定义新属性,因此你需要明白它们是有别于对象的。
【04】需要注意的是,可通过String(),Number()或Boolean()构造函数来显式创建包装对象:
let s = "test", n = 1, b = true;// 一个字符串、数字和布尔值
let S = new String(s); // 一个字符串对象
let N = new Number(n); // 一个数值对象
let B = new Boolean(b); // 一个布尔对象
JS会在必要时将包装对象转换成原始值,因此上段代码中的对象S、N和B常常——但不总是——表现的和值s、n和b一样。
“==”等于运算符将原始值和其包装对象视为相等,但“===”全等运算符将它们视为不等。
通过typeof运算符可以看到原始值和其包装对象的不同。
网友评论