zoukankan      html  css  js  c++  java
  • 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 。

  • 相关阅读:
    数据安全:1.98亿购车者的购车记录公之于众
    【作者面对面问答】包邮送《Redis 5设计与源码分析》5本
    关于区块链学习资料
    《机器学习》周志华西瓜书学习笔记(九):聚类
    Bulletproof零知识证明
    数据接收合并
    数据接收合并
    数据接收合并
    数据接收合并
    Tomcat 8 Host-Manager配置访问的方法,全网唯一正确配置
  • 原文地址:https://www.cnblogs.com/zmztya/p/10192443.html
Copyright © 2011-2022 走看看