如何正确承诺JSON.用bluebird解析方法

How to promisify correctly JSON.parse method with bluebird

本文关键字:方法 bluebird 何正确 承诺 JSON      更新时间:2023-09-26

我试图承诺JSON.parse方法,但不幸的是没有任何运气。这是我的尝试:

Promise.promisify(JSON.parse, JSON)(data).then((result: any) => {...

但是我得到以下错误

Unhandled rejection Error: object

Promise.promisify被认为是接受回调函数的异步函数。JSON.parse没有此功能,因此此处不能使用promisify

如果你想从一个可能同步throw的函数中创建一个承诺返回函数,Promise.method是最好的方法:

var parseAsync = Promise.method(JSON.parse);
…
parseAsync(data).then(…);

或者,您只需要使用Promise.resolve来启动您的链:

Promise.resolve(data).then(JSON.parse).then(…);

来得太晚了,但我完全可以理解为什么您可能想要一个永远不会抛出异常的承诺JSON解析方法。如果没有其他原因,那么从代码中删除样板文件try/catch处理。而且,我认为同步行为没有理由不应该被包装在承诺中。这里:

function promisedParseJSON(json) {
    return new Promise((resolve, reject) => {
        try {
            resolve(JSON.parse(json))
        } catch (e) {
            reject(e)
        }
    })
}

使用,如:

fetch('/my-json-doc-as-string')
  .then(promisedParseJSON)
  .then(carryOn)
  .catch(dealWithIt)

首先,JSON.parse不是异步函数。所以,不要试图承诺它。


因为我想创建一个承诺链,其中JSON。解析站在顶部

然后,简单地创建一个用解析后的JSON对象解析的Promise,如下所示

Promise.resolve(JSON.parse(data))
    .then(...)

现在,对于你的实际问题,你会得到错误,

Unhandled rejection Error: object

因为,如果你的承诺链被拒绝,你没有处理它。因此,不要忘记附加一个catch处理程序,就像这样

Promise.resolve(JSON.parse(data))
    .then(...)
    .catch(...)

READ THIS我在这里展示的方法有一个问题,正如Bergi在评论中指出的那样。如果JSON.parse调用失败,那么错误将被同步抛出,您可能不得不在Promise代码周围编写try...catch。相反,人们会像Bergi在他的回答中建议的那样写,只使用数据创建一个Promise对象,然后在该Promise链上执行JSON.parse