分享更有价值
被信任是一种快乐

Node中如何使用async函数

文章页正文上

本篇内容介绍了“Node中如何使用async函数”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!利用 async 函数,你可以把基于 Promise 的异步代码写得就像同步代码一样。一旦你使用 async 关键字来定义了一个函数,那你就可以在这个函数内使用 await 关键字。当一个 async 函数被调用时,它会返回一个 Promise。当这个 async 函数返回一个值时,那个 Promise 就会被实现;而如果函数中抛出一个错误,那么 Promise 就会被拒绝。await 关键字可以被用来等待一个 Promise 被解决并返回其实现的值。如果传给 await 的值不是一个 Promise,那它会把这个值转化为一个已解决的 Promise。

constrp=require('request-promise')
asyncfunctionmain(){
constresult=awaitrp('https://google.com')
consttwenty=await20
//睡个1秒钟
awaitnewPromise(resolve=>{
setTimeout(resolve,1000)
})
returnresult
}
main()
.then(console.log)
.catch(console.error)

如果你的 Node.js 应用已经在使用Promise,那你只需要把原先的链式调用改写为对你的这些 Promise 进行 await。如果你的应用还在使用回调函数,那你应该以渐进的方式转向使用 async 函数。你可以在开发一些新功能的时候使用这项新技术。当你必须调用一些旧有的代码时,你可以简单地把它们包裹成为 Promise 再用新的方式调用。要做到这一点,你可以使用内建的 util.promisify方法:

constutil=require('util')
const{readFile}=require('fs')
constreadFileAsync=util.promisify(readFile)
asyncfunctionmain(){
constresult=awaitreadFileAsync('.gitignore')
returnresult
}
main()
.then(console.log)
.catch(console.error)

express 本来就支持 Promise,所以在 express 中使用 async 函数是比较简单的:

constexpress=require('express')
constapp=express()
app.get('/',async(request,response)=>{
//在这里等待Promise
//如果你只是在等待一个单独的Promise,你其实可以直接将将它作为返回值返回,不需要使用await去等待。
constresult=awaitgetContent()
response.send(result)
})
app.listen(process.env.PORT)

但正如 Keith Smith 所指出的,上面这个例子有一个严重的问题——如果 Promise 最终被拒绝,由于这里没有进行错误处理,那这个 express 路由处理器就会被挂起。为了修正这个问题,你应该把你的异步处理器包裹在一个对错误进行处理的函数中:

constawaitHandlerFactory=(middleware)=>{
returnasync(req,res,next)=>{
try{
awaitmiddleware(req,res,next)
}catch(err){
next(err)
}
}
}
//然后这样使用:
app.get('/',awaitHandlerFactory(async(request,response)=>{
constresult=awaitgetContent()
response.send(result)
免费云主机、域名
}))

比如说你正在编写这样一个程序,一个操作需要两个输入,其中一个来自于数据库,另一个则来自于一个外部服务:

asyncfunctionmain(){
constuser=awaitUsers.fetch(userId)
constproduct=awaitProducts.fetch(productId)
awaitmakePurchase(user,product)
}

在这个例子中,会发生什么呢?你的代码会首先去获取 user,然后获取 product,最后再进行支付。如你所见,由于前两步之间并没有相互依赖关系,其实你完全可以将它们并行执行。这里,你应该使用 Promise.all 方法:

asyncfunctionmain(){
const[user,product]=awaitPromise.all([
Users.fetch(userId),
Products.fetch(productId)
])
awaitmakePurchase(user,product)
}

而有时候,你只需要其中最快被解决的 Promise 的返回值——这时,你可以使用 Promise.race 方法。“Node中如何使用async函数”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注云技术网站,小编将为大家输出更多高质量的实用文章!

相关推荐: es6中object新增了什么方法

这篇文章主要介绍了es6中object新增了什么方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇es6中object新增了什么方法文章都会有所收获,下面我们一起来看看吧。 es6中的object方法:1、“Object.is()…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册