扫码关注官方订阅号
这是我的解决方案:
function resolve(path, obj) { return path.split('.').reduce(function(prev, curr) { return prev ? prev[curr] : null }, obj || self) }
使用示例:
resolve("document.body.style.width") // 或者 resolve("style.width", document.body) // 或者甚至使用数组索引 // (someObject已在问题中定义) resolve("part.0.size", someObject) // 当中间属性未定义时返回null: resolve('properties.that.do.not.exist', {hello:'world'})
有两种访问对象属性的方式:点表示法:something.bar 和方括号表示法:something['bar']。
方括号中的值可以是任何表达式。因此,如果属性名存储在变量中,必须使用方括号表示法:
var something = { bar: 'foo' }; var foo = 'bar'; // both x = something[foo] and something[foo] = x work as expected console.log(something[foo]); console.log(something.bar)
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
扫描下载App
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
这是我的解决方案:
使用示例:
有两种访问对象属性的方式:点表示法:something.bar 和方括号表示法:something['bar']。
方括号中的值可以是任何表达式。因此,如果属性名存储在变量中,必须使用方括号表示法: