我正在嘗試使用動態名稱存取物件的屬性。這可能嗎?
const something = { bar: "Foobar!" }; const foo = 'bar'; something.foo; // The idea is to access something.bar, getting "Foobar!"
P粉0989790482023-10-11 12:39:43
這是我的解決方案:
function resolve(path, obj) { return path.split('.').reduce(function(prev, curr) { return prev ? prev[curr] : null }, obj || self) }
使用範例:
resolve("document.body.style.width") // or resolve("style.width", document.body) // or even use array indexes // (someObject has been defined in the question) resolve("part.0.size", someObject) // returns null when intermediate properties are not defined: resolve('properties.that.do.not.exist', {hello:'world'})
P粉7558637502023-10-11 12:17:15
有兩種存取屬性的方法 物件:
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)