如何正确承诺JSON.用bluebird解析方法
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.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
。
相关文章:
- electronic BrowserWindow的最小高度和宽度在hide()show()方法之后不起作用
- 有没有任何方法可以将控制器从文件加载到ui路由器$stateProvider中
- 数组在递归方法中设置为null
- 打破承诺链的好方法是什么
- 在使用Polymer'加载所有json文件后执行方法;s的核心ajax
- 使用“;这个“;JavaScript原型方法中的关键字
- 序列化数据属性中对象的最可靠方法
- 使用Objective-C的JavaScript注入方法
- 有没有一种方法可以添加相同的项目val=“0”;4〃;到JavaScript中数组的每个对象
- 有没有一种方法可以防止img get请求使用css或js发生
- Javascript,有没有一种方法可以将数组写成没有逗号或空格的单个文本字符串
- toBoolean方法类似于toString
- 如何在单击复选框后调用控制器方法
- 是否有任何方法可以使用jQuery替换在数组中定义值的文本
- 递归使用 eval() 是检查程序执行的好方法吗?
- 如何在webView,Android中从@JavascriptInterface方法调用Javascript
- toLocaleDateString和toLocaleString方法不尊重机器时区
- 有条件更新d3.js力图中节点的最佳方法
- 用".then"链接bluebird中的异步函数.什么是最好的方法
- 如何正确承诺JSON.用bluebird解析方法