javascript 之 面向对象理解对象

Posted zmztyas

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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():可以取到给定属性的描述符。

    

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 。










以上是关于javascript 之 面向对象理解对象的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript基础概念之----面向对象----理解对象

深入理解JavaScript系列(17):面向对象编程之概论

VSCode自定义代码片段——JS中的面向对象编程

javascript面向对象之闭包

JavaScript之——面向对象

VSCode自定义代码片段9——JS中的面向对象编程