首页 > web前端 > 前端问答 > koa和node有什么关系

koa和node有什么关系

青灯夜游
发布: 2021-12-13 11:20:46
原创
2078 人浏览过

koa是一个基于Node.js平台的web开发框架,依赖“node v7.6.0”或ES2015及更高版本和async方法支持;Koa并没有捆绑任何中间件,而是提供了一套优雅的方法,帮助用户快速而愉快地编写服务端应用程序。

koa和node有什么关系

本教程操作环境:windows7系统、nodejs 12.19.0版,DELL G3电脑。

Koa -- 基于 Node.js 平台的下一代 web 开发框架

Koa 是一个新的 web 框架,由 Express 幕后的原班人马打造, 致力于成为 web 应用和 API 开发领域中的一个更小、更富有表现力、更健壮的基石。 通过利用 async 函数,Koa 帮你丢弃回调函数,并有力地增强错误处理。 Koa 并没有捆绑任何中间件, 而是提供了一套优雅的方法,帮助您快速而愉快地编写服务端应用程序。

Koa 是为了解决 Express 的一些设计缺陷而诞生的。它的中间件可以通过 async function 来编写,await next() 可以中断中间件的执行,等到后面所有中间件执行完之后再执行,通过 await next() 来实现洋葱模型。

还有一个特点是对 request 和 response 的简化处理,这两者都挂载在 ctx 上使用,返回的内容也可以通过直接赋值来使用,如:ctx.response.body = fs.createStream('really_large.xml')。

而且 Koa 把路由功能砍掉了,它是通过中间件来实现的,这是一种微内核的极简思路。

核心功能(Koa 的说明文档):

  • 比 Express 更极致的 request / response 简化,如:
    • ctx.status = 200
    • ctx.body = 'hello node'
  • 使用 async function 实现的中间件。
  • 有“暂停执行”的能力。
  • 在异步的情况下也符合洋葱模型。
  • 精简内核,所有额外功能都移到中间件里实现。

安装

Koa 依赖 node v7.6.0 或 ES2015及更高版本和 async 方法支持.

你可以使用自己喜欢的版本管理器快速安装支持的 node 版本:

$ nvm install 7
$ npm i koa
$ node my-koa-app.js
登录后复制

使用 Babel 实现 Async 方法

要在 node < 7.6 版本的 Koa 中使用 async 方法, 我们推荐使用 babel's require hook.

require(&#39;babel-register&#39;);
// 应用的其余 require 需要被放到 hook 后面
const app = require(&#39;./app&#39;);
登录后复制

要解析和编译 async 方法, 你至少应该有 transform-async-to-generator 或 transform-async-to-module-method 插件.

例如, 在你的 .babelrc 文件中, 你应该有:

{
  "plugins": ["transform-async-to-generator"]
}
登录后复制

你也可以用 env preset 的 target 参数 "node": "current" 替代.

应用程序

Koa 应用程序是一个包含一组中间件函数的对象,它是按照类似堆栈的方式组织和执行的。 Koa 类似于你可能遇到过的许多其他中间件系统,例如 Ruby 的 Rack ,Connect 等,然而,一个关键的设计点是在其低级中间件层中提供高级“语法糖”。 这提高了互操作性,稳健性,并使书写中间件更加愉快。

这包括诸如内容协商,缓存清理,代理支持和重定向等常见任务的方法。 尽管提供了相当多的有用的方法 Koa 仍保持了一个很小的体积,因为没有捆绑中间件。

必修的 hello world 应用:

const Koa = require(&#39;koa&#39;);
const app = new Koa();
app.use(async ctx => {
  ctx.body = &#39;Hello World&#39;;
});
app.listen(3000);
登录后复制

更多node相关知识,请访问:nodejs 教程!!

以上是koa和node有什么关系的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板