| |
|
开发:
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项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |
数据统计 |