javascript 之 面向对象【理解对象】

第五版本

6.1.1  属性类型

     1/数据属性 :包含有数据值的问题。有内部有特性和属性,是为了实现javaScript引擎用的,在javaScript中不能直接访问 

[[Configurable]] :表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特
性,或者能否把属性修改为访问器属性。像前面例子中那样直接在对象上定义的属性,它们的
这个特性默认值为 true 。
? [[Enumerable]] :表示能否通过 for-in 循环返回属性。像前面例子中那样直接在对象上定
义的属性,它们的这个特性默认值为 true 。
? [[Writable]] :表示能否修改属性的值。像前面例子中那样直接在对象上定义的属性,它们的
这个特性默认值为 true 。
? [[Value]] :包含这个属性的数据值。读取属性值的时候,从这个位置读;写入属性值的时候,
把新值保存在这个位置。这个特性的默认值为 undefined 。

若修改特性,则可通过提供的Object.defineProperty()方法,此方法接收三个参数:对象,对象属性名,描述符对象。案例

复制代码
//Object.defineProperty()不建议在IE8中使用
var
person = {}; Object.defineProperty(person, "name", { writable: false, value: "Nicholas" }); alert(person.name); //"Nicholas" person.name = "Greg"; alert(person.name); //"Nicholas" //把 configurable 设置为 false ,表示不能从对象中删除属性。如果对这个属性调用 delete ,则 //在非严格模式下什么也不会发生,而在严格模式下会导致错误。而且,一旦把属性定义为不可配置的, //就不能再把它变回可配置了。此时,再调用 Object.defineProperty() 方法修改除 writable 之外 的特性,都会导致错误: var person = {}; Object.defineProperty(person, "name", { configurable: false, value: "Nicholas" }); //抛出错误 Object.defineProperty(person, "name", { configurable: true, value: "Nicholas" });
复制代码

      2/访问属性

         ? [[Configurable]] :表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特

            性,或者能否把属性修改为数据属性。对于直接在对象上定义的属性,这个特性的默认值为true 。

         ? [[Enumerable]] :表示能否通过 for-in 循环返回属性。对于直接在对象上定义的属性,这

           个特性的默认值为 true 。

         ? [[Get]] :在读取属性时调用的函数。默认值为 undefined 。

         ? [[Set]] :在写入属性时调用的函数。默认值为 undefined 

        访问器属性不能直接定义,必须要用Object.defineProperty()来定义。案例:

         

复制代码
var book = {
_year: 2004,
edition: 1
};
Object.defineProperty(book, "year", {
get: function(){
return this._year;
},
set: function(newValue){
if (newValue > 2004) {
this._year = newValue;
this.edition += newValue - 2004;
}
}
});
book.year = 2005;
alert(book.edition); //2
复制代码

6.1.2定义多属性

     Object.defineProperties()方法:可以通过描述符定义多个属性(IE9+才能用)。案例

复制代码
var book = {};
Object.defineProperties(book, {
_year: {
    value: 2004
},
edition: {
    value: 1
},
year: {
   get: function(){
       return this._year;
    },
   set: function(newValue){
      if (newValue > 2004) {
         this._year = newValue;
         his.edition += newValue - 2004;
      }
   }
}
});
复制代码

6.1.3读取属性

     Object.getOwnPropertyDescriptor():可以取到给定属性的描述符。

    

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
var book = {};
Object.defineProperties(book, {
_year: {
   value: 2004
},
edition: {
   value: 1
},
year: {
   get: function(){
   return this._year;
},
set: function(newValue){
   if (newValue > 2004) {
     this._year = newValue;
      this.edition += newValue - 2004;
    }
  }
}
});

  

 

 

[[Configurable]] :表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为数据属性。对于直接在对象上定义的属性,这个特性的默认值为true 。 [[Enumerable]] :表示能否通过 for-in 循环返回属性。对于直接在对象上定义的属性,这个特性的默认值为 true 。 [[Get]] :在读取属性时调用的函数。默认值为 undefined 。 [[Set]] :在写入属性时调用的函数。默认值为 undefined 。

posted @   zmztyas  阅读(155)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示