使用 JavaScript 的點表示法字串安全地設定物件屬性
可以使用 lodash 的 set 方法在任何層級安全地設定屬性。設定一級屬性是相當簡單的。巢狀的屬性訪問很複雜,對此應該使用一個經過測試的庫,例如 lodash。
可以透過以下方式設定深度巢狀物件 -
示例
let _ = require("lodash");
let obj = {
a: {
b: {
foo: "test"
},
c: 2
}
};
_.set(obj, "a.b.foo", "test1");
_.set(obj, "a.c", { test2: "bar" });
console.log(obj);輸出
結果如下 -
{ a: { b: { foo: 'test1' }, c: { test2: 'bar' } } }也可以按照以下方式編寫自己的 setUpdateProp 函式 -
const setUpdateProp = (object, path, value) => {
if (path.length === 1) object[path[0]] = value;
else if (path.length === 0) throw error;
else {
if (object[path[0]])
return setUpdateProp(object[path[0]], path.slice(1), value);
else {
object[path[0]] = {};
return setUpdateProp(object[path[0]], path.slice(1), value);
}
}
};可以透過傳遞一個數組來訪問屬性來使用它。
示例
var obj = {
level1:{
level2:{
level3:{
name: "Foo"
}
},
anotherLevel2: "bar"
}
};
setUpdateProp(obj, ["level1", "level2"], "FooBar");
console.log(obj);輸出
結果如下 -
{ level1: { level2: 'FooBar', anotherLevel2: 'bar' } }
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP