可能是一个愚蠢的问题,但为什么 map mutate 对象数组。
var obj = {
items: [{
value: 1,
selected: true
}, {
value: 2,
selected: false
}]
};
var items = obj.items.map(i => {
if (i.value === 2) i.selected = true;
return i;
});
console.log(obj);Run Code Online (Sandbox Code Playgroud)
当您映射数组时,它不会创建对象的副本。它只是遍历数组。
如果您不想改变对象,则必须创建该对象的副本:
var items = obj.items.map(item => {
let i = JSON.parse(JSON.stringify(item))
if (i.value === 2) i.selected = true;
return i;
});
Run Code Online (Sandbox Code Playgroud)
如果您想快速解决.map一组对象的不可变版本,您可以使用扩展运算符:
myArrayOfObjects.map(({...obj}) => { });
Run Code Online (Sandbox Code Playgroud)
例子:
const foo = [];
for(let i = 0; i < 5; i++) {
foo.push({label: "foo"});
}
const bar = foo.map(({...val}) => {
val.id = Math.random();
return val;
});
console.log(foo);
console.log(bar);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2034 次 |
| 最近记录: |