IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 后端项目构建——Koa -> 正文阅读

[JavaScript知识库]后端项目构建——Koa

1.为什么选择Koa

? ?Koa是由Express幕后原班人马打造的,相对于Express来说,Koa的体积更小,表现力更强,而且很干净,没有任何中间件等多余的插件,整体代码也就1000多行。而且提供了一整套优雅的方法,可以愉快而快速地编写服务端应用程序。

2.安装Koa

? Koa需要 node v7.6.0或更高版本来支持ES2015、异步方法,你可以安装自己支持的node版本。

使用 npm i koa 命令下载koa

? 使用Koa开发很简单,不用像Express一样使用脚手架生成繁杂的文件夹和文件,仅用3行代码,即可构建一个Koa服务。在项目中新建一个app.js文件,并编写以下代码:

? 编写这3行代码之后,在命令行工具中执行以下代码:

node app.js

? 现在可以在本地的8889端口访问服务:

? 看起来什么都没有,是因为没有给返回对象,Koa提供一个Context对象,简称ctx。表示一个HTTP的请求与回复,可以将返回的数据放在ctx.response.body中,这样前端就能接收到返回的数据,可以把app.js文件修改如下:

?

修改完成之后先运行一个app.js文件,在访问http://localhost:8889,即可得到Hello World的返回:

?

如此就完成了简单的Koa项目的构建,虽然功能很简单,但还是可以很明显地看出代码量相对于Express来说少了很多。

3.中间件

? Koa最大的特色就是中间件,它本身是没有任何中间件的,所有中间件都需要手动进行开发。用一个日志输出器来举例。

?

? ?Logger就是一个中间件,因为它在收到HTTP请求与返回HTTP请求之间,用来实现某种功能。之后使用app.use()来加载中间件。

? Koa中每个中间件都会有两个参数:一个是ctx;另一个是next。ctx就是本次请求和回复的主体对象,里面包含请求和返回的数据。next是执行下一步的函数,只要调用就会自动跳到下一个中间件。当只有一个中间件时,可能看不出next的作用;当有多个中间件时,就能看出next的作用。如:

?

这里定义并加载了3个中间件,分别为one、two、three。

结果如下:

?---one

---two

为什么结果没有“---three”呢?仔细看代码,因为在two函数中没有使用next来传递执行权,所以,即使加载了three函数,在调用two函数的时候就结束传递了,因此根本就不会调用three函数。

4.异步函数

? Koa对异步函数的处理也很友好,无须使用promise来一层层包裹语句,使用async函数即可。

说明:main函数定义为一个异步函数,使用promise来模拟异步操作。首先在main函数加上async标识,之后在异步操作前加上await标识,如此main函数就会在await后面的语句执行完成之后才会进行下一步操作。相比于promise来说,更加容易使用,且不会陷入promise一层套一层的恐怖循环中去。

?5.处理报错信息

? ?一个程序运行时不可能不报错,Koa对报错的处理也十分简单,可以使用ctx.throw()方法直接抛出指定类型的错误,如404或500错误。对于更具体的报错,在每个中间件中,都可以使用try...catch来捕获错误,但这样操作未免有些麻烦,可以直接让最外层的中间件来捕获错误。

?在最外层的handler函数中监听了所有中间件的执行过程,若有报错,则会被catch之后判断报错类型,返回出去。try...catch语法结构也很简单,在try中执行需要执行的代码,如果代码出错,则会被下面的catch捕获到,然后执行catch中的语句。在main函数中使用ctx.throw()方法来报出500的错误,之后这个错误就会被handlerError函数捕获并且返回。

?

?

?

?

?

?

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-23 12:23:04  更:2021-10-23 12:25:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/29 20:24:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计