淺談Javascript數(shù)據(jù)屬性與訪問(wèn)器屬性
ES5中對(duì)象的屬性可以分為‘?dāng)?shù)據(jù)屬性'和‘訪問(wèn)器屬性'兩種。
數(shù)據(jù)屬性一般用于存儲(chǔ)數(shù)據(jù)數(shù)值,訪問(wèn)器屬性對(duì)應(yīng)的是set/get操作,不能直接存儲(chǔ)數(shù)據(jù)值。
數(shù)據(jù)屬性特性:value、writable、enumerable、configurable。
解釋:configurable:true/false,是否可以通過(guò)delete刪除屬性,能否修改屬性的特性,能否把屬性修改為訪問(wèn)器屬性,默認(rèn)false;
enumerable:true/false,是否可以通過(guò)for in循環(huán)返回,默認(rèn)false;
writable:true/false,是否可以修改屬性的值,默認(rèn)false;
value:undefined,設(shè)置屬性的值,默認(rèn)undefined。
訪問(wèn)器屬性特性:set、get、enumerable、configurable。
解釋:configurable:true/false,是否可以通過(guò)delete刪除屬性,能否修改屬性的特性,能否把屬性修改為訪問(wèn)器屬性,默認(rèn)false;
enumerable:true/false,是否可以通過(guò)for in循環(huán)返回,默認(rèn)false;
set:function,讀取屬性值時(shí)調(diào)用的函數(shù);
get:function,修改屬性值時(shí)調(diào)用的函數(shù)。
將屬性添加到對(duì)象或修改現(xiàn)有屬性的特性使用Object.defineProperty() 或 Object.defineproperties()方法;
Object.defineProperty(object, propertyname, descriptor):
參數(shù)解釋:object:需要添加或修改屬性的對(duì)象;
propertyname:屬性的名稱,字符串格式;
descriptor:屬性的描述,設(shè)置數(shù)據(jù)屬性或訪問(wèn)器屬性的特性。
實(shí)例分析:
數(shù)據(jù)屬性:
var emp = { name:'tom' }; Object.defineProperty(emp,'name',{ writable:false }); emp.name = 'jery'; console.log(emp.name);//輸出tom,因?yàn)橐呀?jīng)設(shè)置了writable為false Object.defineProperty(emp,'age',{ configurable:false, writable:true, value:22 }); console.log(emp.age);//輸出22,因?yàn)樵O(shè)置了value為22 emp.age = 25; console.log(emp.age);//輸出25,設(shè)置了writable為true delete emp.age; console.log(emp.age);//輸出25,設(shè)置了configurable為false,此屬性刪除不了
訪問(wèn)器屬性:
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,沒(méi)有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的讀取出來(lái) delete emp.age; console.log(emp.age);//輸出undefined,configurable為true,可以使用delete方法將emp.age屬性刪除
備注:訪問(wèn)器屬性可以起到很好的保護(hù)作用,當(dāng)只有g(shù)et方法時(shí),就實(shí)現(xiàn)只讀不能寫;反之,只有set時(shí),便是只能寫入而不能讀取
以上就是小編為大家?guī)?lái)的淺談Javascript數(shù)據(jù)屬性與訪問(wèn)器屬性全部?jī)?nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
js驗(yàn)證真實(shí)姓名與身份證號(hào),手機(jī)號(hào)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇js驗(yàn)證真實(shí)姓名與身份證號(hào),手機(jī)號(hào)的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07使用JS location實(shí)現(xiàn)搜索框歷史記錄功能
這篇文章主要介紹了使用JS location實(shí)現(xiàn)搜索框歷史記錄功能,本文通過(guò)實(shí)例 代碼講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12不使用中間變量,交換int型的 a, b兩個(gè)變量的值。
群中的題目,不過(guò)這樣大眾臉的題想必大家都見(jiàn)過(guò),就看能玩出什么新花招2010-10-10javascript 鼠標(biāo)拖動(dòng)圖標(biāo)技術(shù)
剛剛學(xué)習(xí)了個(gè)js的小技術(shù),還蠻好玩的,以后會(huì)把做的一些小例子貼上來(lái),方便自己也可以跟大家一起分享學(xué)習(xí)成果,哈哈~~2010-02-02uniapp原生tabbar設(shè)置并添加數(shù)字角標(biāo)或小紅點(diǎn)提示功能
這篇文章主要給大家介紹了關(guān)于uniapp原生tabbar設(shè)置并添加數(shù)字角標(biāo)或小紅點(diǎn)提示功能的相關(guān)資料,在相應(yīng)的頁(yè)面中完成對(duì)消息的處理,如果有新消息,則在tabBar頁(yè)面中顯示紅點(diǎn)提醒用戶,需要的朋友可以參考下2023-08-08獲取3個(gè)數(shù)組不重復(fù)的值的具體實(shí)現(xiàn)
先用concat拼接數(shù)組 ,再使用一個(gè)對(duì)象、一個(gè)新數(shù)組(用于存放不重復(fù)的數(shù)組)具體實(shí)現(xiàn)如下,感興趣的朋友可以參考2013-12-12