- Mastering Immutable.js
- Adam Boduch
- 244字
- 2021-07-08 10:30:11
Updating list values
When the new value of a list item depends on the current value, you can use the update() method instead of set(). It takes a function that gets the current value as an argument and the return value is used as the new value, as shown here:
const myList = List.of(
Map.of('total', 0, 'step', 5),
Map.of('total', 5, 'step', 10)
);
const increment = map => map.set(
'total',
map.get('total') + map.get('step')
);
const myChangedList = myList
.update(0, increment)
.update(1, increment);
console.log('myList', myList.toJS());
// -> myList [ { total: 0, step: 5 }, { total: 5, step: 10 } ]
console.log('myChangedList', myChangedList.toJS());
// -> myChangedList [ { total: 5, step: 5 }, { total: 15, step: 10 } ]
Each value in this list is a map with two keys: total and step. The increment() function updates the total value based on its current value and the step value. The function then returns the new map that's created by calling set(). If you know the index of the list value that you want to update, you can pass the increment() function to update(), along with the index. In this example, I've updated both list items.
We could have achieved the same result by calling set() on the list, but this would involve manually getting the value from the list first, since we depend on it. Using update() is simpler because the value that we need is given to us as a function argument.
- Instant Testing with CasperJS
- 跟小海龜學Python
- Mastering Scientific Computing with R
- Visual Basic程序設計與應用實踐教程
- SQL Server 2012數據庫管理與開發項目教程
- Android底層接口與驅動開發技術詳解
- 大數據分析與應用實戰:統計機器學習之數據導向編程
- Mastering React
- Frank Kane's Taming Big Data with Apache Spark and Python
- Programming with CodeIgniterMVC
- Go語言編程
- Getting Started with Python
- Java 7 Concurrency Cookbook
- Raspberry Pi Robotic Projects
- JavaScript編程精解(原書第3版)