我正在使用 React 和 ES6。所以我遇到了以下情况:我有一个状态,其中包含一个对象数组,假设a = [{id: 1, value: 1}, {id: 2, value: 2}]
处于 状态Object A
,然后我将列表传递给Object B
props,Object B
(在构造函数中)将列表复制到它自己的状态并调用一个函数map
在我返回的地方使用函数b = [{id: 1, value: 1, text: 'foo'}, {id: 2, value: 2, text: 'foo'}]
(添加(text, value)
到每个对象中),所以它虽然没有发生变异a
,Object A
但确实发生了变异。
所以我做了一些测试:
const a = [{id: 1, value: 1}, {id: 2, value: 2}] // suppose it is in object A
addText = (list) => {
return list.map((item) => {item.text = "foo"; return item})
}
const b = addText(a) // suppose it is in object B
所以在我的假设下a !== b
,但是a
被 变异了addText
,所以他们是平等的。
在大型项目中程序员会犯错误(我在这里犯过!)应该如何处理这种情况以避免以这种方式改变对象?(示例试图represeta
作为state
用于Object A
其是从react的组分)