ECMAScript 5中的属性描述符详解
属性描述符是ES5中新增的概念,其作用是给对象的属性增加更多的控制。
Object.defineProperty
要研究属性描述符,首先要谈谈 Object.defineProperty 方法。这个方法的作用是给对象定义新属性或修改已存在的属性。其原型如下:
Object.defineProperty(obj, prop, descriptor)
使用示例:
var obj = { };
Object.defineProperty(obj, 'attr', { value: 1 });
上面一段代码给obj对象增加了一个名为attr的属性,值为1。相当于:
var obj = { };
obj.attr = 1;
相比起来,Object.defineProperty 的写法看似更为复杂。但是,它最大的奥秘在于其第三个参数。
数据描述符
假设我们希望attr是一个只读属性,就可以加上 writable 数据描述符:
var obj = { };
Object.defineProperty(obj, 'attr', {
value: 1,
writable: false
});
console.log(obj.attr);
obj.attr = 2; // fail
console.log(obj.attr);
执行以上程序可以发现,两次打印出来的attr的值都是1,也就是说对属性的写入失败。然而,这样的结果会有点莫名其妙,因为赋值语句的执行没有异常,却失败了,试想如果在大片的代码中出现这样的问题,就很难排查出来。事实上,只要以严格模式运行代码,就会产生异常:
'use strict'; // 进入严格模式
var obj = { };
Object.defineProperty(obj, 'attr', {
value: 1,
writable: false
});
obj.attr = 2; // throw exception
下面再来看看另一个数据描述符 enumerable ,它可以控制属性是否能被枚举。如果只是简单地定义一个属性,这个属性是可以在for...in循环中被枚举出来的:
var obj = { };
obj.attr = 1;
for (var i in obj) { console.log(obj[i]); }
enumerable 可以将其“藏”起来:
var obj = { };
Object.defineProperty(obj, 'attr', {
value: 1,
enumerable: false
});
for (var i in obj) { console.log(obj[i]); }
以上是 ECMAScript 5中的属性描述符详解 的全部内容, 来源链接: utcz.com/z/325957.html