js進階程式設計——資料屬性和訪問器屬性

來源:互聯網
上載者:User

標籤:log   預設值   通過   obj   des   迴圈   return   logs   刪除   

ES5中對象的屬性可以分為“資料屬性”和“訪問器屬性”兩種。

資料屬性一般用於儲存資料數值,訪問器屬性對應的是set/get操作,不能直接儲存資料值。

資料屬性分為 configurable   enumerable writable value

解釋:configurable: 表示能否通過delete刪除屬性重而重新定義屬性,能否修改屬性的特性,或者能否把屬性修改為訪問器屬性。

  enumerable:表示能否通過for-in迴圈返回屬性。

  writable:表示能否修改屬性的值。

  value:包含這個屬性的資料值。讀取屬性值的時候,從這個位置度,寫入屬性值的時候把新值儲存在這個位置。這個特性的預設值為undefined

對於直接在對象上定義的屬性,它們的[[configurable]] [[enumerable]] [[writable]] 特性都被設定為true  value則被設定成指定的值。

例子:

1 var person = {2     name:"Nicholas"      3 };

person對象的configurable   enumerable writable都是預設值都為true

訪問器屬性特性:set、get、enumerable、configurable。

 解釋:configurable:true/false,是否可以通過delete刪除屬性,能否修改屬性的特性,能否把屬性修改為訪問器屬性,預設false;

        enumerable:true/false,是否可以通過for in迴圈返回,預設false;

        set:function,讀取屬性值時調用的函數;

        get:function,修改屬性值時調用的函數。

將屬性添加到對象或修改現有屬性的特性使用Object.defineProperty() 或 Object.defineproperties()方法;

    Object.defineProperty(object, propertyname, descriptor):

    參數解釋:object:需要添加或修改屬性的對象;

         propertyname:屬性的名稱,字串格式;

         descriptor:屬性的描述,設定資料屬性或訪問器屬性的特性。

 

  執行個體分析:

  資料屬性:

    var emp = {

      name:‘tom‘

    };

 

    Object.defineProperty(emp,‘name‘,{

      writable:false

    });

    emp.name = ‘jery‘;
    console.log(emp.name);//輸出tom,因為已經設定了writable為false

      

    Object.defineProperty(emp,‘age‘,{

      configurable:false,

      writable:true,

      value:22

    });

    console.log(emp.age);//輸出22,因為設定了value為22

    emp.age = 25;

    console.log(emp.age);//輸出25,設定了writable為true

    delete emp.age;

    console.log(emp.age);//輸出25,設定了configurable為false,此屬性刪除不了

 

  訪問器屬性:

    var emp ={

      _name:‘tom‘,

      _age:20

    };

    

    Object.defineProperty(emp,‘name‘,{

      get:function(){

          return this._name;

        }

    });

    console.log(emp.name);//輸出tom,由get方法返回_name的值

    emp.name = ‘jery‘;

    console.log(emp.name);//輸出tom,沒有set方法,修改不了_name的值 

 

    Object.defineProperty(emp,‘age‘,{

      configurable:true,

      get:function(){

        return this._age;

      }

      set:function(age){

        this._age = age;

      }

    });

    emp.age = 25;  
    console.log(emp.age)//輸出25,emp.age=25是使用set方法將25賦值給_age,emp.age是使用get方法將_age的讀取出來

    delete emp.age;

    console.log(emp.age);//輸出undefined,configurable為true,可以使用delete方法將emp.age屬性刪除

 

  備忘:訪問器屬性可以起到很好的保護作用,當只有get方法時,就實現唯讀不能寫;反之,只有set時,便是只能寫入而不能讀取

 

js進階程式設計——資料屬性和訪問器屬性

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.