Transaction(事务)
Transaction 是底层 API,在绝大多数场景下 action 或 runInAction 会是更好的选择
transaction(worker: () => void)
可以用来批量更新,在事务结束前不会通知任何观察者。transaction
接收一个无参数的 worker
函数作为参数并运行它。
这个函数完成运行前不会通知任何观察者。transaction
返回 worker
函数返回的任何值。
注意 transaction
完全是同步运行的。
Transactions 可以嵌套。只有在完成最外面的 transaction
后,其他等待的 reaction 才会运行。
import {observable, transaction, autorun} from "mobx";
const numbers = observable([]);
autorun(() => console.log(numbers.length, "numbers!"));
// 输出: '0 numbers!'
transaction(() => {
transaction(() => {
numbers.push(1);
numbers.push(2);
});
numbers.push(3);
});
// 输出: '3 numbers!'