ECMAScript 中有两种属性:数据属性和访问器属性。
数据属性
数据属性包含一个数据值的位置。在这个位置可以读取和写入值。
Configurable:表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特性,默认值为 true。
Enumerable:表示能否通过 for-in 循环返回属性。默认值为 true。
Writable:表示能否修改属性的值。默认值为 true。
Value:包含这个属性的数据值。默认值为 undefined。
要修改属性默认的特性,必须使用 ECMAScript 5的 Object.defineProperty() 方法。这个方法接收三个参数:属性所在的对象、属性的名字和一个描述符对象。其中,描述符对象的属性必须是:configurable、enumerable、writable 和 value。
1 | var person = {}; |
2 | Object.defineProperty(person, "name", { |
3 | writable: false, |
4 | value: "Jake" |
5 | }); |
6 | console.log(person.name); //"Jake" |
7 | person.name = "Greg"; |
8 | console.log(person.name); //"Jake" |
writable 设置为 false 时,不可修改属性的值。
1 | var person = {}; |
2 | Object.defineProperty(person, "name", { |
3 | configurable: false, |
4 | value: "Jake" |
5 | }); |
6 | console.log(person.name); //"Jake" |
7 | delete person.name; |
8 | console.log(person.name); //"Jake" |
configurable 设置为 false 时,表示不能从对象中删除属性。
1 | var person = {}; |
2 | Object.defineProperty(person, "name", { |
3 | configurable: false, |
4 | value: "Jake" |
5 | }); |
6 | // 抛出错误 |
7 | Object.defineProperty(person, "name", { |
8 | configurable: true, |
9 | value: "Jake" |
10 | }); |
一旦把属性定义为不可配置的,就不能再把它变回可配置了。
访问器属性
访问器属性不包含数据值;它们包含一对儿getter 和setter 函数。访问器属性有如下4 个特性。
Configurable:表示能否通过delete 删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为数据属性。默认值为true。
Enumerable:表示能否通过for-in 循环返回属性。默认值为true。
Get:在读取属性时调用的函数。默认值为undefined。
Set:在写入属性时调用的函数。默认值为undefined。
访问器属性不能直接定义,必须使用Object.defineProperty()来定义。
1 | var book = { |
2 | _year: 2004, |
3 | edition: 1 |
4 | }; |
5 | Object.defineProperty(book, "year", { |
6 | get: function(){ |
7 | return this._year; |
8 | }, |
9 | set: function(newValue){ |
10 | if (newValue > 2004) { |
11 | this._year = newValue; |
12 | this.edition += newValue - 2004; |
13 | } |
14 | } |
15 | }); |
16 | book.year = 2005; |
17 | console.log(book.edition); //2 |