亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

ECMAScript 5中的屬性描述符詳解

2024-05-06 16:15:39
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了ECMAScript 5中的屬性描述符詳解,本文講解了Object.defineProperty、數據描述符、存取描述符、獲取屬性描述符、對象控制等內容,需要的朋友可以參考下
 

屬性描述符是ES5中新增的概念,其作用是給對象的屬性增加更多的控制。

Object.defineProperty

要研究屬性描述符,首先要談談 Object.defineProperty 方法。這個方法的作用是給對象定義新屬性或修改已存在的屬性。其原型如下:

復制代碼代碼如下:

Object.defineProperty(obj, prop, descriptor)

使用示例:
復制代碼代碼如下:

var obj = { };
Object.defineProperty(obj, 'attr', { value: 1 });

上面一段代碼給obj對象增加了一個名為attr的屬性,值為1。相當于:
復制代碼代碼如下:

var obj = { };
obj.attr = 1;

相比起來,Object.defineProperty 的寫法看似更為復雜。但是,它最大的奧秘在于其第三個參數。

 

數據描述符

假設我們希望attr是一個只讀屬性,就可以加上 writable 數據描述符:

復制代碼代碼如下:

var obj = { };
Object.defineProperty(obj, 'attr', {
    value: 1,
    writable: false
});
console.log(obj.attr);
obj.attr = 2; // fail
console.log(obj.attr);

執行以上程序可以發現,兩次打印出來的attr的值都是1,也就是說對屬性的寫入失敗。然而,這樣的結果會有點莫名其妙,因為賦值語句的執行沒有異常,卻失敗了,試想如果在大片的代碼中出現這樣的問題,就很難排查出來。事實上,只要以嚴格模式運行代碼,就會產生異常:
復制代碼代碼如下:

'use strict'; // 進入嚴格模式
var obj = { };
Object.defineProperty(obj, 'attr', {
    value: 1,
    writable: false
});
obj.attr = 2;  // throw exception

下面再來看看另一個數據描述符 enumerable ,它可以控制屬性是否能被枚舉。如果只是簡單地定義一個屬性,這個屬性是可以在for...in循環中被枚舉出來的:
復制代碼代碼如下:

var obj = { };
obj.attr = 1;
for (var i in obj) { console.log(obj[i]); }
enumerable 可以將其“藏”起來:

 

var obj = { };
Object.defineProperty(obj, 'attr', {
    value: 1,
    enumerable: false
});
for (var i in obj) { console.log(obj[i]); }


執行上面一段代碼,會發現控制臺什么也沒輸出,因為此時attr屬性無法被枚舉了。

 

講到這里,大家可能有一個疑問,屬性描述符能否被修改?比方說一個只讀屬性是否可以再次定義為可寫?其實這取決于另一個數據描述符 configurable ,它可以控制屬性描述符能否被更改。

復制代碼代碼如下:

var obj = { };
Object.defineProperty(obj, 'attr', {
    value: 1,
    writable: false,
    configurable: true
});
Object.defineProperty(obj, 'attr', {
    writable: true
});
obj.attr = 2;

上面一段代碼先把attr定義為只讀屬性,然后又重新定義為可寫。所以對attr的寫入是成功的。

 

存取描述符

存取描述符類似面向對象中的get/set訪問器。

復制代碼代碼如下:

var obj = { };
Object.defineProperty(obj, 'attr', {
    set: function(val) { this._attr = Math.max(0, val); },
    get: function() { return this._attr; }
});
obj.attr = -1;
console.log(obj.attr); // 0

在上面一段代碼中,對attr的訪問事實上變成了對_attr的訪問,而且在set函數中限制了最小值為0。

 

獲取屬性描述符

前面所述都是設置屬性描述符,那如何獲取已設置的描述符呢?Object.getOwnPropertyDescriptor 可以完成此項工作。

復制代碼代碼如下:

var obj = { };
Object.defineProperty(obj, 'attr', {
    value: 1,
    writable: false,
    configurable: true
});
var desc = Object.getOwnPropertyDescriptor(obj, 'attr');
console.dir(desc);

 

對象控制

前面說的 Object.defineProperty ,其操作的是對象的屬性,而下面說的三個方法則直接操作對象。

Object.preventExtensions 可以使對象無法擁有新的屬性:

復制代碼代碼如下:

var obj = { };
obj.attr = 1;
Object.preventExtensions(obj);
obj.attr2 = 2; //fail

Object.seal 可以使對象僅剩屬性值可以修改(如果屬性為只讀,則連屬性值都無法修改):
復制代碼代碼如下:

var obj = { };
obj.attr = 1;
Object.seal(obj);
obj.attr = 1.5;
delete obj.attr; // fail

Object.freeze 可以使對象完全無法被修改:
復制代碼代碼如下:

var obj = { };
obj.attr = 1;
Object.freeze(obj);
obj.attr = 1.5; // fail
obj.attr2 = 2; //fail

然后大家可能又會問,怎么知道某個對象是否曾經被preventExtensions、seal或者freeze呢?答案就是分別調用 Object.isExtensible 、 Object.isSealed 、 Object.isFrozen ,這三個函數的用法比較簡單,就不再累贅了。

 

總的來說,通過屬性描述符可以進一步嚴格控制對象,加強程序邏輯的嚴謹性,唯一不足的就是,ES5在IE9里面才基本實現(IE9還不支持嚴格模式),考慮到國內IE8份額還比較高的情況,這套東西目前只能在移動端瀏覽器和Node.js里面用了。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成年人精品视频| 一个色综合导航| 伦理中文字幕亚洲| 欧美一级免费视频| 91久久在线视频| 这里只有精品丝袜| 欧美精品在线观看| 青青草一区二区| 91中文字幕在线观看| 亚洲自拍偷拍色图| 欧美一级视频一区二区| 精品一区二区三区四区| 国产精品pans私拍| 国产自产女人91一区在线观看| 欧美激情视频在线观看| 欧美国产日韩一区二区| 日韩av资源在线播放| 2025国产精品视频| 欧美天天综合色影久久精品| 欧美日韩激情视频8区| 国产精品第100页| 欧美电影免费播放| 91精品中国老女人| 国产精品美女免费视频| xxxxx91麻豆| 国产精品欧美一区二区三区奶水| 69久久夜色精品国产69乱青草| 久久精品99无色码中文字幕| 欧美特级www| 亚洲3p在线观看| 久久精视频免费在线久久完整在线看| 欧美黑人一级爽快片淫片高清| 久久久女人电视剧免费播放下载| 人人澡人人澡人人看欧美| 日韩小视频网址| 亚洲va欧美va国产综合剧情| 欧美性猛交xxxx乱大交3| 欧美综合一区第一页| 精品国产1区2区| 亚洲最大福利网| 久久久精品999| 国产日韩在线观看av| 欧美日韩国产精品一区| 欧美日韩一区二区免费视频| 国产亚洲日本欧美韩国| 亚洲精品综合久久中文字幕| 日韩中文字幕av| 欧美电影《睫毛膏》| 91av在线看| 国产精品一区二区三区毛片淫片| 一区二区福利视频| 欧美黑人性视频| 日韩欧美中文免费| 国产精品视频免费在线观看| 日本精品视频在线播放| 久久国产精品偷| 欧美在线视频网站| 久久亚洲一区二区三区四区五区高| 国产精品人成电影| 国产一区二区三区在线观看网站| 人人澡人人澡人人看欧美| 欧美做受高潮1| 亚洲三级av在线| 91丝袜美腿美女视频网站| 久久久久久亚洲精品中文字幕| 中文字幕欧美在线| 欧美激情videoshd| 日韩免费视频在线观看| 欧美成人亚洲成人日韩成人| 91精品久久久久久久久久久| 日韩电影中文字幕在线观看| 欧美成人精品不卡视频在线观看| 欧美性猛交xxxx久久久| 亚洲九九九在线观看| 在线亚洲男人天堂| 亚洲精品国产综合久久| 日本中文字幕久久看| 91九色在线视频| 日韩av在线网站| 最近更新的2019中文字幕| 国产欧美一区二区三区视频| 亚洲精美色品网站| 国产精品第一区| 中日韩美女免费视频网站在线观看| 91免费的视频在线播放| 欧美视频在线观看 亚洲欧| 欧美激情视频在线| 色妞在线综合亚洲欧美| 这里只有精品视频在线| 国产日韩在线看| 国产成人激情视频| 国产精品亚洲综合天堂夜夜| 日韩精品高清在线| 中文字幕一区二区三区电影| 国产精品久久久久久av福利软件| 国模私拍一区二区三区| 亚洲欧美日韩国产中文专区| 亚洲欧美日韩天堂| 国产综合色香蕉精品| 麻豆国产精品va在线观看不卡| 精品国产一区二区三区四区在线观看| 日韩美女在线观看一区| 91在线免费观看网站| 国产精品露脸自拍| 久热精品视频在线观看| 91探花福利精品国产自产在线| 色哟哟入口国产精品| 欧美日韩中文字幕在线视频| 日本一区二区在线播放| 日韩乱码在线视频| 欧美巨猛xxxx猛交黑人97人| 88国产精品欧美一区二区三区| 久久99精品久久久久久青青91| 国产日产亚洲精品| 午夜精品久久久久久99热| 日本精品久久久久影院| 亚洲一区二区三区视频播放| 日韩在线视频导航| 红桃av永久久久| 国产精品亚洲美女av网站| 亚洲精品aⅴ中文字幕乱码| 成人h猎奇视频网站| 亚洲欧美国产一区二区三区| 久久久久中文字幕| 久久电影一区二区| 欧美大码xxxx| 国产精品wwww| 国产精品日韩欧美综合| 中文字幕国产精品久久| 亚洲人成电影在线观看天堂色| 欧日韩在线观看| 亚洲性线免费观看视频成熟| 欧美有码在线视频| 亚洲免费视频在线观看| 亚洲在线免费看| 欧美又大又粗又长| 国产精品老牛影院在线观看| 亚洲人成毛片在线播放| 国产91精品最新在线播放| 日本成人精品在线| 福利视频导航一区| 日本三级韩国三级久久| 欧美日韩一区二区在线| 午夜精品久久久久久99热软件| 日韩av中文在线| 亚洲欧洲日产国产网站| 国产精品视频男人的天堂| 欧美人与性动交a欧美精品| 国产精品亚洲第一区| 日本欧美精品在线| 欧美激情2020午夜免费观看| 精品欧美激情精品一区| 91热精品视频| 亚洲国产欧美一区二区三区同亚洲| 久久久久久久亚洲精品| 亚洲精品日韩丝袜精品| 国产亚洲激情视频在线| 91精品国产高清久久久久久久久| 亚洲2020天天堂在线观看| 亚洲精品国产suv| 亚洲精品久久久一区二区三区| 奇门遁甲1982国语版免费观看高清| 欧美xxxx做受欧美.88| 日韩国产一区三区|