JavaScript如何根据属性获取属性的父级
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,这篇文章主要介绍"JavaScript如何根据属性获取属性的父级",在日常操作中,相信很多人在JavaScript如何根据属性获取属性的父级问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法
千家信息网最后更新 2025年01月21日JavaScript如何根据属性获取属性的父级
这篇文章主要介绍"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就是代理对象
尝试使用obj.parent获取它的父级
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}
可以看到已经成功获取了属性的父级那么它可以用来干什么呢?
1. 定位父级
obj.a.parent // Proxy {a: Proxy, b: Proxy}
2. 生成兄弟属性
var p = obj.ap.parent.c = {}obj.c // Proxy {parent: Proxy}
3. 检测是否为兄弟属性
var p1 = obj.a.parent, p2 = obj.b.parentvar p3 = obj.a.aa.parent, p4 = obj.b.bb.parentp1 == p2 // truep3 == p4 // false
4. 定位最高父级
p5 = obj.a.aawhile(p5.parent) { p5 = p5.parent}p5 // Proxy {a: Proxy, b: Proxy}p5 == obj // true
到此,关于"JavaScript如何根据属性获取属性的父级"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
属性
学习
对象
代理
兄弟
方法
更多
定位
帮助
实用
最高
成功
接下来
上代
就是
文章
理论
知识
篇文章
网站
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
青海观堂网络技术有限公司
朗驰网络视频服务器售后
警告 自拍 服务器
武汉临空港网络安全学院食堂
赣州app软件开发公司
语音服务器连接不上wifi
沈阳软件开发公司多吗
匿名登录ftp服务器
杭州工控软件开发服务费
java的数据库很难学
吕梁网络安全教育平台
数据库追加查询规则
供应商visio数据库
wamps服务器搭建
上海夺畅网络技术有限公司待遇怎么样
有哪些游戏关闭了服务器
方舟海贼服务器是什么意思
网络安全防护技术培训简报
华硕服务器主板bmc 口
中国科技互联网龙头股
两台服务器ha一个ip
企腾网络技术信息
中山app软件开发有用吗
长春短视频软件开发服务商
创业公司租服务器
长春有哪些ipfs服务器
谷歌服务器怎么添加管理员
网络安全工程师最高岗位
服务器可以放几个程序
文件服务器权限管理软件