繁体   English   中英

如何在 promise 在不使用 async/await 的情况下解决后,如何使用 Immer.js 对草稿 object 进行编辑

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

我正在尝试对来自 Immer 的 object 草案进行编辑,这取决于 promise 解析。 我了解如何使用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

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

只需返回一个 promise 用于produce回调 function:

在线版本

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);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM