面向对象【1】:数据属性

一、数据属性有 4 个描述其行为的特性

  • [[Configurable]]: 表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为访问器属性。
  • [[Enumerable]]:表示能否通过 for-in 循环返回属性。
  • [[Writable]]:表示能否修改属性的值。
  • [[Value]]:包含这个属性的数据值。读取属性值的时候,从这个位置读;写入属性值的时候,把新值保存在这个位置。这个特性的默认值为 undefined。
var person = { 
     name: "Nicholas", 
     age: 29, 
     job: "Software Engineer", 
     sayName: function(){ 
         alert(this.name); 
     } 
}; 
复制代码

这里创建了一个名为 name 的属性,为它指定的值是”Nicholas”。也就是说,[[Value]]特性将
被设置为”Nicholas”,而对这个值的任何修改都将反映在这个位置。

二、 Object.defineProperty()

要修改属性默认的特性,必须使用 ECMAScript 5 的 Object.defineProperty()方法。这个方法接收三个参数:属性所在的对象、属性的名字和一个描述符对象。其中,描述符(descriptor)对象的属性必须是configurable、enumerable、writable 和 value。设置其中的一或多个值,可以修改对应的特性值。

  1. 这个例子创建了一个名为 name 的属性,它的值”Nicholas”是只读的。这个属性的值是不可修改

的,如果尝试为它指定新值,则在非严格模式下,赋值操作将被忽略;在严格模式下,赋值操作将会导
致抛出错误。

var person = {}; 
Object.defineProperty(person, "name", { 
 writable: false, 
 value: "Nicholas" 
}); 
alert(person.name); //"Nicholas" 
person.name = "Greg"; 
alert(person.name); //"Nicholas"
复制代码
  1. 类似的规则也适用于不可配置的属性。例如把 configurable 设置为 false,表示不能从对象中删除属性。如果对这个属性调用 delete,则在非严格模式下什么也不会发生,而在严格模式下会导致错误。
var person = {}; 
Object.defineProperty(person, "name", { 
 configurable: false, 
 value: "Nicholas" 
}); 
alert(person.name); //"Nicholas" 
delete person.name; 
alert(person.name); //"Nicholas"
复制代码
  1. 一旦把属性定义为不可配置的,就不能再把它变回可配置了。此时,再调用 Object.defineProperty()方法修改除 writable 之外的特性,都会导致错误:
var person = {}; 
Object.defineProperty(person, "name", { 
 configurable: false, 
 value: "Nicholas" 
}); 
//抛出错误
Object.defineProperty(person, "name", { 
 configurable: true, 
 value: "Nicholas" 
}); 
复制代码
© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享