2
2
3
3
## 定义
4
4
5
- 对象是 JavaScript 语言最主要的数据类型,三种原始类型的值——数值、字符串、布尔值——在一定条件下,也会自动转为对象,也就是原始类型的“包装对象”。
5
+ 对象是 JavaScript 语言最主要的数据类型,三种原始类型的值——数值、字符串、布尔值——在一定条件下,也会自动转为对象,也就是原始类型的“包装对象”(wrapper) 。
6
6
7
- 所谓“包装对象”,就是分别与数值 、字符串、布尔值相对应的 ` Number ` 、` String ` 、` Boolean ` 三个原生对象。这三个原生对象可以把原始类型的值变成(包装成)对象。
7
+ 所谓“包装对象”,指的是与数值 、字符串、布尔值分别相对应的 ` Number ` 、` String ` 、` Boolean ` 三个原生对象。这三个原生对象可以把原始类型的值变成(包装成)对象。
8
8
9
9
``` javascript
10
10
var v1 = new Number (123 );
11
11
var v2 = new String (' abc' );
12
12
var v3 = new Boolean (true );
13
- ```
14
-
15
- 上面代码中,基于原始类型的值,生成了三个对应的包装对象。
16
13
17
- ``` javascript
18
14
typeof v1 // "object"
19
15
typeof v2 // "object"
20
16
typeof v3 // "object"
@@ -24,14 +20,21 @@ v2 === 'abc' // false
24
20
v3 === true // false
25
21
```
26
22
27
- 包装对象的最大目的,首先是使得 JavaScript 的对象涵盖所有的值,其次使得原始类型的值可以方便地调用某些方法 。
23
+ 上面代码中,基于原始类型的值,生成了三个对应的包装对象。可以看到, ` v1 ` 、 ` v2 ` 、 ` v3 ` 都是对象,且与对应的简单类型值不相等 。
28
24
29
- ` Number ` 、` String ` 和` Boolean ` 如果不作为构造函数调用(即调用时不加` new ` ),常常用于将任意类型的值转为数值、字符串和布尔值。
25
+ 包装对象的设计目的,首先是使得“对象”这种类型可以覆盖 JavaScript 所有的值,整门语言有一个通用的数据模型,其次是使得原始类型的值也有办法调用自己的方法。
26
+
27
+ ` Number ` 、` String ` 和` Boolean ` 这三个原生对象,如果不作为构造函数调用(即调用时不加` new ` ),而是作为普通函数调用,常常用于将任意类型的值转为数值、字符串和布尔值。
30
28
31
29
``` javascript
32
- Number (123 ) // 123
33
- String (' abc' ) // "abc"
34
- Boolean (true ) // true
30
+ // 字符串转为数值
31
+ Number (' 123' ) // 123
32
+
33
+ // 数值转为字符串
34
+ String (123 ) // "123"
35
+
36
+ // 数值转为布尔值
37
+ Boolean (123 ) // true
35
38
```
36
39
37
40
上面这种数据类型的转换,详见《数据类型转换》一节。
@@ -40,11 +43,11 @@ Boolean(true) // true
40
43
41
44
## 实例方法
42
45
43
- 三种包装对象各自提供了许多实例方法,详见后文。这里介绍两种它们共同具有、从` Object ` 对象继承的方法:` valueOf ` 和` toString ` 。
46
+ 三种包装对象各自提供了许多实例方法,详见后文。这里介绍两种它们共同具有、从` Object ` 对象继承的方法:` valueOf() ` 和` toString() ` 。
44
47
45
48
### valueOf()
46
49
47
- ` valueOf ` 方法返回包装对象实例对应的原始类型的值。
50
+ ` valueOf() ` 方法返回包装对象实例对应的原始类型的值。
48
51
49
52
``` javascript
50
53
new Number (123 ).valueOf () // 123
@@ -54,7 +57,7 @@ new Boolean(true).valueOf() // true
54
57
55
58
### toString()
56
59
57
- ` toString ` 方法返回对应的字符串形式。
60
+ ` toString() ` 方法返回对应的字符串形式。
58
61
59
62
``` javascript
60
63
new Number (123 ).toString () // "123"
@@ -64,7 +67,7 @@ new Boolean(true).toString() // "true"
64
67
65
68
## 原始类型与实例对象的自动转换
66
69
67
- 原始类型的值,可以自动当作包装对象调用 ,即调用包装对象的属性和方法。这时,JavaScript 引擎会自动将原始类型的值转为包装对象实例,在使用后立刻销毁实例 。
70
+ 某些场合,原始类型的值会自动当作包装对象调用 ,即调用包装对象的属性和方法。这时,JavaScript 引擎会自动将原始类型的值转为包装对象实例,并在使用后立刻销毁实例 。
68
71
69
72
比如,字符串可以调用` length ` 属性,返回字符串的长度。
70
73
@@ -86,7 +89,7 @@ var strObj = new String(str)
86
89
strObj .length // 3
87
90
```
88
91
89
- 上面代码中,字符串` abc ` 的包装对象提供了多个属性。
92
+ 上面代码中,字符串` abc ` 的包装对象提供了多个属性, ` length ` 只是其中之一 。
90
93
91
94
自动转换生成的包装对象是只读的,无法修改。所以,字符串无法添加新属性。
92
95
@@ -118,19 +121,8 @@ Number.prototype.double = function () {
118
121
return this .valueOf () + this .valueOf ();
119
122
};
120
123
121
- (123 ).double ()
122
- // 246
124
+ (123 ).double () // 246
123
125
```
124
126
125
- 上面代码在` 123 ` 外面必须要加上圆括号,否则后面的点运算符(` . ` )会被解释成小数点。
126
-
127
- 但是,这种自定义方法和属性的机制,只能定义在包装对象的原型上,如果直接对原始类型的变量添加属性,则无效。
128
-
129
- ``` javascript
130
- var s = ' abc' ;
131
-
132
- s .p = 123 ;
133
- s .p // undefined
134
- ```
127
+ 上面代码在` String ` 和` Number ` 这两个对象的原型上面,分别自定义了一个方法,从而可以在所有实例对象上调用。注意,最后一张的` 123 ` 外面必须要加上圆括号,否则后面的点运算符(` . ` )会被解释成小数点。
135
128
136
- 上面代码直接对字符串` abc ` 添加属性,结果无效。主要原因是上面说的,这里的包装对象是自动生成的,赋值后自动销毁,所以最后一行实际上调用的是一个新的包装对象。
0 commit comments