[英]How to promisify correctly JSON.parse method with bluebird
我试图宣传JSON.parse
方法,但遗憾的是没有任何运气。 这是我的尝试:
Promise.promisify(JSON.parse, JSON)(data).then((result: any) => {...
但是我收到以下错误
Unhandled rejection Error: object
Promise.promisify
被认为是采用回调函数的异步函数。 JSON.parse
没有这样的功能,所以你不能在这里使用promisify
。
如果你想从一个可能同步throw
的函数创建一个promise- Promise.method
函数, Promise.method
是要走的路:
var parseAsync = Promise.method(JSON.parse);
…
parseAsync(data).then(…);
或者,您只想使用Promise.resolve
来启动您的链:
Promise.resolve(data).then(JSON.parse).then(…);
首先, JSON.parse
不是异步函数。 所以,不要试图宣传它。
因为我想创建一个承诺链,其中JSON.parse站在顶部
然后,简单地创建一个使用解析的JSON对象解析的Promise,就像这样
Promise.resolve(JSON.parse(data))
.then(...)
现在,根据您的实际问题,您收到错误,
Unhandled rejection Error: object
因为,如果你的承诺链被拒绝,你就不会处理它。 所以,不要忘记附加一个catch处理程序,就像这样
Promise.resolve(JSON.parse(data))
.then(...)
.catch(...)
阅读本文我在这里展示的方法存在问题,正如Bergi在评论中所指出的那样。 如果JSON.parse
调用失败,则错误将同步抛出,您可能必须编写try...catch
绕Promise
代码。 相反,人们会像Bergi在他的回答中所建议的那样编写它,只用数据创建一个Promise对象,然后在Promise链上做JSON.parse
。
迟到了,但我完全理解为什么你可能想要一个永远不会抛出异常的promisified JSON解析方法。 如果没有别的,那么从你的代码中删除样板try / catch处理。 此外,我认为没有理由不应将同步行为包含在promises中。 所以在这里:
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)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.