我试图承诺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
。