您好,登錄后才能下訂單哦!
這篇文章主要介紹“JavaScript如何根據屬性獲取屬性的父級”,在日常操作中,相信很多人在JavaScript如何根據屬性獲取屬性的父級問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JavaScript如何根據屬性獲取屬性的父級”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
function mObj(Obj) {
var obj = new Proxy(Obj, {
set: function (obj, pro, val, Pro) {
if (typeof val == 'object') {
val.parent = Pro
val = mObj(val)
}
obj[pro] = val
return val
}
})
return obj
}
我們只需要用 mObj 方法來初始化我們需要代理的對象
var obj = mObj({})
注!只能添加空對象,否則其屬性將失去代理
obj.a = {}
obj.b = {}
obj.a.aa = {}
obj.b.bb = {}
console.log(obj) // Proxy {a: Proxy, b: Proxy}
Proxy就是代理對象
console.log(obj.a.parent,obj.b.parent)
// Proxy {a: Proxy, b: Proxy} Proxy {a: Proxy, b: Proxy}
console.log(obj.a.aa.parent,obj.b.bb.parent)
// Proxy {parent: Proxy, aa: Proxy} Proxy {parent: Proxy, bb: Proxy}
可以看到已經成功獲取了屬性的父級那么它可以用來干什么呢?
obj.a.parent // Proxy {a: Proxy, b: Proxy}
var p = obj.a
p.parent.c = {}
obj.c // Proxy {parent: Proxy}
var p1 = obj.a.parent, p2 = obj.b.parent
var p3 = obj.a.aa.parent, p4 = obj.b.bb.parent
p1 == p2 // true
p3 == p4 // false
p5 = obj.a.aa
while(p5.parent) {
p5 = p5.parent
}
p5 // Proxy {a: Proxy, b: Proxy}
p5 == obj // true
到此,關于“JavaScript如何根據屬性獲取屬性的父級”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。