Transaction(事务)

Transaction 是底层 API,在绝大多数场景下 actionrunInAction 会是更好的选择

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!'

results matching ""

    No results matching ""