如何在不使用 async/await 的情况下使用 Immer.js 对草稿对象执行编辑

How to perform edits to a draft object using Immer.js after promise has resolved without using async/await

我正在尝试对来自 Immer 的草稿对象进行编辑,该草稿对象取决于承诺解决。我了解如何使用 async/await 语法执行此操作,(见下文)

import produce from 'immer';

Promise.resolve({ eggs: 0 }).then(
  produce(async (eggCounter) => { const n = (await 5); eggCounter.eggs += n; })
).then(console.log)

但是当我尝试将其转换为使用显式 Promise API 时,它不起作用:

import produce from 'immer';

Promise.resolve({ eggs: 0 }).then(
  produce((eggCounter) => { Promise.resolve(5).then((n) => eggCounter.eggs += n) })
).then(console.log)

以上生成错误 Uncaught (in promise) TypeError: illegal operation attempted on a revoked proxy

如何修改第二个示例,使其(充分)等同于第一个示例?

只是 return produce 回调函数的承诺:

在线版本

Promise.resolve({ eggs: 0 }).then(
  produce((eggCounter) => Promise.resolve(5).then((n) => { eggCounter.eggs += n; }))
).then(console.log)

清晰版

Promise.resolve({ eggs: 0 }).then(
  produce((eggCounter) => {
    return Promise.resolve(5).then((n) => {
      eggCounter.eggs += n;
    });
  })
).then(console.log);