使用 Immutable.js 在 OrderedMap 中添加项目
Add an Item in OrderedMap with Immutable.js
如何在 OrderedMap 的末尾添加项目?
我试过了
this.boxes = this.boxes.setIn(data);
感谢您的帮助
OrderedMap 本身并没有真正的 "end"。此外,如果您想向 Map 添加一个项目,您也需要一个密钥。
所以要么你使用 set
方法添加键值对:
this.boxes = this.boxes.set(key,data);
或者你把它转换成一个列表,你可以把它添加到最后并保持一个清晰的迭代顺序,这意味着你确实有一个 "end".
this.boxes = this.boxes.toList().push(data);
一种可行的方法是使用 concat
var boxes = Immutable.OrderedMap({
box1: {
id:1
},
box2: {
id:2
}
});
var data = Immutable.fromJS({
box3: {
id:3
}
});
var newBoxes = boxes.concat(data);
console.log(newBoxes.toJS());
将打印出:
Object { box1: Object {
id: 1 }, box2: Object {
id: 2 }, box3: Object {
id: 3 } }
如何在 OrderedMap 的末尾添加项目?
我试过了
this.boxes = this.boxes.setIn(data);
感谢您的帮助
OrderedMap 本身并没有真正的 "end"。此外,如果您想向 Map 添加一个项目,您也需要一个密钥。
所以要么你使用 set
方法添加键值对:
this.boxes = this.boxes.set(key,data);
或者你把它转换成一个列表,你可以把它添加到最后并保持一个清晰的迭代顺序,这意味着你确实有一个 "end".
this.boxes = this.boxes.toList().push(data);
一种可行的方法是使用 concat
var boxes = Immutable.OrderedMap({
box1: {
id:1
},
box2: {
id:2
}
});
var data = Immutable.fromJS({
box3: {
id:3
}
});
var newBoxes = boxes.concat(data);
console.log(newBoxes.toJS());
将打印出:
Object { box1: Object { id: 1 }, box2: Object { id: 2 }, box3: Object { id: 3 } }