学习架构:html
因为Koa2已经支持ES6及更高版本,包括支持async方法,因此请读者保证Node.js版本在7.6.0以上。若是须要在低于7.6的版本中应用Koa的async方法,建议使用Babel hook。示例代码以下:node
require('babel-register'); // 应用的其他 require 须要被放到hook后面 const app = require('./app');
在安装Koa以前,读者须要先建立项目的目录。新建文件夹koa2-tutorial/用来存放示例代码,而后在koa2-tutorial/根目录下初始化项目,生成配置文件package.json。命令以下:程序员
npm init
注意:生成的package.json文件用于管理项目中用到的一些安装包npm
项目初始化完成后,在当前目录下新建app.js文件并输出全部程序员都熟知的一句话:json
console.log(“Hello World”)
打开控制台,进入到目录koa2-tutorial/,执行以下命令:浏览器
node app.js
若是控制台成功输出“Hello World”,说明环境正常。至此项目的准备工做已经完成。基本的项目结构应该以下所示:服务器
├── app.jsbabel
├── package.json架构
Koa的安装过程很是简单,只需经过以下命令便可安装最新版本:app
npm install koa --save
注意:Koa的版本信息会自动保存在package.json中。
Koa安装完成以后,修改app.js文件实现启动Web服务器的功能。代码以下所示:
const koa = require('koa'); const app = new koa(); app.listen(3000, () => { console.log('server is running at http://localhost:3000'); });
而后运行app.js文件并打开浏览器访问http://localhost:3000,正常状况下,页面将会显示“Not Found”。这是由于在3000端口下启动服务器并进行访问的时候并无对HTTP请求进行响应处理,故而报404 Not Found错误。为了让浏览器显示一些信息,代码还须要作些调整。修改app.js,加入一个简单的中间件处理全部请求。代码以下所示:
app.use(async (ctx, next) => { await next(); ctx.response.type = 'text/html'; ctx.response.body = '<h1>Hello World</h1>'; });
注意:此段代码需放置在服务器启动以前。
从新启动服务器后,再次访问浏览器,将会正常显示“Hello World”。
本节在线视频地址https://camp.qianduan.group/koa2/2/1/1,扫描二维码可观看:
一块儿跟我来学习《Koa与Node.js开发实战》这本书吧。