在 ImmutableJS 中,如何将新数组推送到 Map 中?
In ImmutableJS, how to push a new array into a Map?
如何使用 ImmutableJS 实现以下目标:
myMap.get(key).push(newData);
如果在键处引用的数组是普通 javascript 数组 - 那么您实际上会改变该值 - 因此您的代码将按预期工作(即 - myMap 将包含一个 mutable/mutated 数组在 'key' 处推入了 newData。)但是,这种方式违背了不变性的目的,因此我建议 myMap 中的键引用一个 Immutable.List。在这种情况下,您需要执行以下操作:
var newMap = myMap.set('key', myMap.get('key').push(newData))
您可以进行如下操作:(见此JSBin)
const myMap = Immutable.fromJS({
nested: {
someKey: ['hello', 'world'],
},
});
const myNewMap = myMap.updateIn(['nested', 'someKey'], arr => arr.push('bye'));
console.log(myNewMap.toJS());
// {
// nested: {
// someKey: ["hello", "world", "bye"]
// }
// }
由于 myMap
是不可变的,每当您尝试 set/update/delete 其中的某些数据时,它都会 return 对新数据的引用。因此,您必须将它设置为一个变量才能访问它(在本例中,myNewMap
)。
如何使用 ImmutableJS 实现以下目标:
myMap.get(key).push(newData);
如果在键处引用的数组是普通 javascript 数组 - 那么您实际上会改变该值 - 因此您的代码将按预期工作(即 - myMap 将包含一个 mutable/mutated 数组在 'key' 处推入了 newData。)但是,这种方式违背了不变性的目的,因此我建议 myMap 中的键引用一个 Immutable.List。在这种情况下,您需要执行以下操作:
var newMap = myMap.set('key', myMap.get('key').push(newData))
您可以进行如下操作:(见此JSBin)
const myMap = Immutable.fromJS({
nested: {
someKey: ['hello', 'world'],
},
});
const myNewMap = myMap.updateIn(['nested', 'someKey'], arr => arr.push('bye'));
console.log(myNewMap.toJS());
// {
// nested: {
// someKey: ["hello", "world", "bye"]
// }
// }
由于 myMap
是不可变的,每当您尝试 set/update/delete 其中的某些数据时,它都会 return 对新数据的引用。因此,您必须将它设置为一个变量才能访问它(在本例中,myNewMap
)。