Vue中的Object.defineProperty全面理解
Object.defineProperty理解
定義:Object.defineProperty() 方法會直接在一個對象上定義一個新屬性,或者修改一個對象的現(xiàn)有屬性,并返回此對象。
直接添加
let person = {
? ? name:'張三',
? ? sex:'男',
}
Object.defineProperty(person,'age',{
? ? value:18,
? ? enumerable:true,//控制屬性是否可以枚舉,默認(rèn)值是false,當(dāng)該屬性的值為 true 時,該屬性才會出現(xiàn)在對象的枚舉屬性中。
? ? writable:true,//控制屬性是否可以被修改,默認(rèn)值是false,當(dāng)該屬性的值為 true 時,才能被賦值運算符改變。
? ? configurable:true,//控制屬性是否可以被刪除,默認(rèn)值是false,當(dāng)該屬性的值為 true 時,該屬性能從對應(yīng)的對象上被刪除。 ?
? ? ? ? ? ? ?
})
console.log(person);使用getter、setter
let age_number = 18;
let person = {
? ? name:'張三',
? ? sex:'男',
}
Object.defineProperty(person,'age',{
? ? //value:18,
? ? //enumerable:true,//控制屬性是否可以枚舉,默認(rèn)值是false,當(dāng)該屬性的值為 true 時,該屬性才會出現(xiàn)在對象的枚舉屬性中。
? ? //writable:true,//控制屬性是否可以被修改,默認(rèn)值是false,當(dāng)該屬性的值為 true 時,才能被賦值運算符改變。
? ? //configurable:true,//控制屬性是否可以被刪除,默認(rèn)值是false,當(dāng)該屬性的值為 true 時,該屬性能從對應(yīng)的對象上被刪除。 ?
? ? get(){
? ? ? ? console.log("讀取age屬性");
? ? ? ? return age_number;
? ? },
? ? set(value)
? ? {
? ? ? ? console.log("修改age的值");
? ? ? ? age_number = value;
? ? } ? ? ? ? ? ? ?
})
console.log(person);需要Object.defineProperty()注意點
1.用Object.defineProperty方法創(chuàng)建一個新屬性時,如果不指定configurabel,enumberable,writable特性的默認(rèn)值都是false,修改已定義的屬性特性無限制。
2.Configurable性定義為不可配置就不能把它變回可配置,此時調(diào)用Object.defineProperty修改除writable之外的特性都會報錯。
3.模擬訪問和設(shè)置的行為:想要訪問器屬性模擬默認(rèn)行為的話,必須的在里面新添一個屬性不然會造成循環(huán)引用
var obj={
a:1
};
?
Object.defineProperty(obj,"a",{
get:function(){
return this.a;
},
?
set:function(val){
this.a=val
}
});
obj.a;// Maximum call stack size exceeded會造成循環(huán)引用,狂call不止
person.a → get.call(person) → this.a → person.a ?→ get.call(person) → this.a......
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue-router結(jié)合vuex實現(xiàn)用戶權(quán)限控制功能
這篇文章主要介紹了vue-router結(jié)合vuex實現(xiàn)用戶權(quán)限控制功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11
vue.js路由mode配置之去掉url上默認(rèn)的#方法
今天小編就為大家分享一篇vue.js路由mode配置之去掉url上默認(rèn)的#方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
Vue Router的手寫實現(xiàn)方法實現(xiàn)
這篇文章主要介紹了Vue Router的手寫實現(xiàn)方法實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03

