JS标准库之包装对象

定义

对象是 JavaScript 语言最主要的数据类型,三种原始类型的值(数值、字符串、布尔值),在一定条件下,也会自动转为对象,也就是原始类型的“包装对象”。

所谓“包装对象”,指的是数值、字符串、布尔值分别对应的NumberStringBoolean这三个原生对象。这三个原生对象可以把原始类型变成(包装成)对象。

var v1 = new Number(123);
var v2 = new String('abc');
var v3 = new Boolean(true);

typeof v1 // "object"
typeof v2 // "object"
typeof v3 // "object"

v1 === 123 // false
v2 === 'abc' // false
v3 === true // false

上面代码中,基于原始类型的值,生成了三个对应的包装对象。可以看到,v1v2v3都是对象,且与对应的简单类型值不相等。

// 字符串转为数值
Number('123') // 123

// 数值转为字符串
String(123) // '123'

// 数值转为字符串
Boolean(123) // true

NumberStringBoolean这三个原生对象作为构造函数使用(带有new)时,可以将原始类型的值转为对象;作为普通函数使用(不带有new)时,可以将任意类型的值,转为原始类型的值。

实例

valueOf()

返回包装对象实例对应的原始类型的值。

new Number(123).valueOf() // 123
new String('abc').valueOf() // 'abc'
new Boolean(true).valueOf() // true

toString()

返回对应的字符串的形式。

new Number(123).toString() // '123'
new String('abc').toString() // 'abc'
new Boolean(true).toString() // 'true'

原始类型与实例对象的自动转换

某些场合,原始类型的值会自动当作包装对象调用,即调用包装对象的属性和方法。这是,JavaScript 引擎会自动将原始类型的值转为包装对象实例,并在使用后立刻销毁实例。

'abc'.length // 3

上面代码中,abc是一个字符串,本身不是对象,不能调用length属性。JavaScript 引擎自动将其转为包装对象,在这个对象上调用length属性。调用结束后,这个临时对象就会被销毁。这就叫做原始类型与实例对象的自动转换。

var str = 'abc';
str.length // 3

// 等同于
var strObj = new String(str)
// String {
//   0: "a", 1: "b", 2: "c", length: 3, [[PrimitiveValue]]: "abc"
// }
strObj.length // 3

上面代码中,字符串abc的包装对象提供了多个属性,length只是其中一个。

这些信息可能会帮助到你: 关于我们 | 饿了么返钱 | 捐赠支持

文章名称:JS标准库之包装对象
文章链接:https://www.bysjb.cn/js-library-wrapper.html
THE END
分享
二维码
打赏
< <上一篇
下一篇>>