美文网首页
ECMAScript 属性类型

ECMAScript 属性类型

作者: shadow123 | 来源:发表于2017-08-09 09:36 被阅读0次

    数据属性

    数据属性包含一个数据值的位置。在这个位置可以读取和写入值。

    Configurable:表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特性,默认值为 true。
    Enumerable:表示能否通过 for-in 循环返回属性。默认值为 true。
    Writable:表示能否修改属性的值。默认值为 true。
    Value:包含这个属性的数据值。默认值为 undefined。

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

    var person = {};
    Object.defineProperty(person, "name", {
      writable: false,
      value: "Jake"
    });
    console.log(person.name); //"Jake"
    person.name = "Greg";
    console.log(person.name); //"Jake"
    

    writable 设置为 false 时,不可修改属性的值。

    var person = {};
    Object.defineProperty(person, "name", {
      configurable: false,
      value: "Jake"
    });
    console.log(person.name); //"Jake"
    delete person.name;
    console.log(person.name); //"Jake"
    

    configurable 设置为 false 时,表示不能从对象中删除属性。

    var person = {};
    Object.defineProperty(person, "name", {
      configurable: false,
      value: "Jake"
    });
    // 抛出错误
    Object.defineProperty(person, "name", {
      configurable: true,
      value: "Jake"
    });
    

    一旦把属性定义为不可配置的,就不能再把它变回可配置了。

    访问器属性

    访问器属性不包含数据值;它们包含一对儿getter 和setter 函数。访问器属性有如下4 个特性。

    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;
    console.log(book.edition); //2
    

    相关文章

      网友评论

          本文标题:ECMAScript 属性类型

          本文链接:https://www.haomeiwen.com/subject/hbdfrxtx.html