javascript - 为什么 map 会改变对象数组?
问题描述
可能是一个愚蠢的问题,但为什么 map 会改变对象数组。
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);
解决方案
如果您想快速解决.map
一组对象的不可变版本,您可以使用扩展运算符:
myArrayOfObjects.map(({...obj}) => { });
例子:
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);
推荐阅读
- html - 我可以使用相同的复选框 hack 触发 2 个动作吗?使用 CSS
- genexus - GX 15 U6 Java - OpenAPI(重新)生成
- c# - 将动态生成的输入列表表单数据从视图传递到asp.net中的控制器
- android - 将多个参数传递给 ViewModel Primary Constructor
- javascript - 使用值创建标签的事件监听器
- java - ArrayUtils 无法解析
- javascript - 如何从 Elasticsearch 查询中的嵌套范围访问父字段?
- scala - 为什么需要模式匹配来保留存在类型信息?
- matlab - Matlab中等效的Excel求解器函数
- android - 类型无效 - 需要一个字符串,react-native 错误