JavaScript 中的动态属性赋值
在某些场景下,您可能会遇到需要为对象中深层嵌套的属性赋值的情况结构。但是,您可能只有字符串形式的属性名称。这可能会带来挑战,因为直接访问属性需要遍历整个对象层次结构。
解决方案
为了解决这个问题,我们可以使用 allocate()函数:
function assign(obj, prop, value) { if (typeof prop === "string") prop = prop.split("."); if (prop.length > 1) { var e = prop.shift(); assign(obj[e] = Object.prototype.toString.call(obj[e]) === "[object Object]" ? obj[e] : {}, prop, value); } else obj[prop[0]] = value; }
用法
让我们考虑一个例子:
var obj = {}; var propName = "foo.bar.foobar"; assign(obj, propName, "Value");
解释
通过利用使用 allocate() 函数,您可以动态地将值分配给任何深度级别的属性,即使您只有字符串形式的属性名称。
以上是如何仅使用字符串属性名称为深度嵌套的 JavaScript 对象动态赋值?的详细内容。更多信息请关注PHP中文网其他相关文章!