网站建设资讯

NEWS

网站建设资讯

koa中间件主要知识点有哪些-创新互联

本篇内容介绍了“koa中间件主要知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联是专业的玛曲网站建设公司,玛曲接单;提供成都网站制作、成都网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行玛曲网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

koa中间件中为什么必须且只能调用一次next函数,可以看到如果不调用next,就不会触发dispatch(i+1),下一个中间件就没办法触发,造成假死状态最终请求超时。

koa中间件主要涉及到Promise几个知识点:

async函数返回的是一个Promise对象【所以的中间件都会返回一个promise对象】

async函数内部遇到await调用时会暂停执行await函数,等待返回结果后继续向下执行

async函数内部发生错误会导致返回的Promise变为reject状态

现在我们在回顾之前提出的几个问题:

next()调用为什么需要加await

这也是洋葱圈调用机制的核心,当执行到awaitnext(),会执行next()【调用下一个中间件】等待返回结果,在接着向下执行

koa中间件如何进行Context提供

目标:封装Context,提供request、response的便捷操作方式

//1、定义KoaRequest、KoaResponse、KoaContext

interfaceKoaContext{

request?:KoaRequest;

response?:KoaResponse;

body:String|null;

}

constcontext:KoaContext={

getbody(){

returnthis.response!.body;

},

setbody(body){

this.response!.body=body;

}

};

functioncomposeMiddleware(middlewares:middlewareFn[]){

return(context:KoaContext)=>{

letstart=-1;

functiondispatch(i:number){

//..省略其他代码..

//2、所有的中间件接受context参数

middleware(context,()=>{

returndispatch(i+1);

});

}

returndispatch(0);

};

}

“koa中间件主要知识点有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


网页标题:koa中间件主要知识点有哪些-创新互联
链接URL:http://cdweb.net/article/cdpdhe.html