资讯专栏INFORMATION COLUMN

标准库(三)包装对象

skinner / 303人阅读

摘要:所谓包装对象,指的是与数值字符串布尔值分别相对应的三个原生对象。引擎自动将其转为包装对象,在这个对象上调用属性。调用结束后,这个临时对象就会被销毁自动转换生成的包装对象是只读的,无法修改。

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

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

目的
使得原始类型的值也有办法调用自己的方法。

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

2.实例方法
三种包装对象各自提供了许多实例方法,详见后文。这里介绍两种它们共同具有、从Object对象继承的方法:valueOf()和toString()

2.1valueOf()
valueOf()方法返回包装对象实例对应的原始类型的值。

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

2.2toString()方法返回对应的字符串形式。

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

3原始类型与实例对象的自动转换
某些场合,原始类型的值会自动当作包装对象调用,即调用包装对象的属性和方法。这时,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属性。JavaScript 引擎自动将其转为包装对象,在这个对象上调用length属性。调用结束后,这个临时对象就会被销毁

3.1自动转换生成的包装对象是只读的,无法修改。所以,字符串无法添加新属性。

var s = "Hello World";
s.x = 123;
s.x // undefined
上面代码为字符串s添加了一个x属性,结果无效,总是返回undefined

3.2调用结束后,包装对象实例会自动销毁。这意味着,下一次调用字符串的属性时,实际是调用一个新生成的对象,而不是上一次调用时生成的那个对象,所以取不到赋值在上一个对象的属性。如果要为字符串添加属性,只有在它的原型对象String.prototype上定义
4自定义方法

除了原生的实例方法,包装对象还可以自定义方法和属性,供原始类型的值直接调用。

比如,我们可以新增一个double方法,使得字符串和数字翻倍。

String.prototype.double = function () {
return this.valueOf() + this.valueOf();
};

"abc".double()
// abcabc

Number.prototype.double = function () {
return this.valueOf() + this.valueOf();
};

(123).double() // 246
上面代码在String和Number这两个对象的原型上面,分别自定义了一个方法,从而可以在所有实例对象上调用。注意,最后一张的123外面必须要加上圆括号,否则后面的点运算符(.)会被解释成小数点。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/105892.html

相关文章

  • 标准包装对象

    摘要:所谓包装对象,指的是与数值字符串布尔值分别相对应的三个原生对象。引擎自动将其转为包装对象,在这个对象上调用属性。调用结束后,这个临时对象就会被销毁自动转换生成的包装对象是只读的,无法修改。 所谓包装对象,指的是与数值、字符串、布尔值分别相对应的Number、String、Boolean三个原生对象。这三个原生对象可以把原始类型的值变成(包装成)对象 var v1 = new Numbe...

    Donne 评论0 收藏0
  • 标准包装对象

    摘要:所谓包装对象,指的是与数值字符串布尔值分别相对应的三个原生对象。引擎自动将其转为包装对象,在这个对象上调用属性。调用结束后,这个临时对象就会被销毁自动转换生成的包装对象是只读的,无法修改。 所谓包装对象,指的是与数值、字符串、布尔值分别相对应的Number、String、Boolean三个原生对象。这三个原生对象可以把原始类型的值变成(包装成)对象 var v1 = new Numbe...

    zhunjiee 评论0 收藏0
  • 标准包装对象

    摘要:所谓包装对象,指的是与数值字符串布尔值分别相对应的三个原生对象。引擎自动将其转为包装对象,在这个对象上调用属性。调用结束后,这个临时对象就会被销毁自动转换生成的包装对象是只读的,无法修改。 所谓包装对象,指的是与数值、字符串、布尔值分别相对应的Number、String、Boolean三个原生对象。这三个原生对象可以把原始类型的值变成(包装成)对象 var v1 = new Numbe...

    impig33 评论0 收藏0
  • JavaScript标准系列——包装对象(四)

    摘要:目录导语包装对象的理解三大包装对象的知识点小结导语包装对象是为了弥补基本数据类型的非对象特性而产生的,对于基本类型值而言,本来是不存在属性和方法的,但是我们可以在使用字面量创建字符串时,调用例如的方法,那么其内在原理究竟是什么呢阅读完本篇文 目录 导语 1. 包装对象的理解 2. 三大包装对象的知识点 3. 小结 导语 包装对象是为了弥补基本数据类型的非对象特性而产生的,对于基本类型...

    sean 评论0 收藏0
  • 标准(四)包装对象二number

    摘要:对象概述作为构造函数,它主要用于生成布尔值的包装对象实例。无输出上面代码的第一个例子之所以得到,是因为对应的包装对象实例是一个对象,进行逻辑运算时,被自动转化成布尔值因为所有对象对应的布尔值都是。 1.Boolean 对 象 1.1概述作为构造函数,它主要用于生成布尔值的包装对象实例。 false对应的包装对象实例,布尔运算结果也是true。 if (new Boolean(false...

    MAX_zuo 评论0 收藏0

发表评论

0条评论

skinner

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<