Koa2 学习笔记(第一天)

前一段开始接触了Koa2,写这个笔记是希望能够把知识点记录下来,也能够记录自己的学习历程。

Koa2是什么?

Koa是下一代的Nodo.js web框架。
Koa2是由Express原班人马打造的轻量级框架。它去除了Express里面的很多中间件,另外把原来的callback回调函数的写法换成了async await的写法。

如何安装Koa2?

因为Node7.6才开始支持async await,所以使用Koa2,就需要Node7.6以上的环境。
Node.js的官网地址:https://nodejs.org

安装好Node之后,使用npm安装koa2

npm init          // 初始化package.json
npm install koa   // 安装koa2

hello world 代码

const Koa = require('koa');
const app = new Koa();

app.use( ctx => {
    ctx.body = 'hello world!';
})

app.listen(3000);
console.log('koa2 is started at port 3000!');

如何启动demo?

node app.js

也可以使用vscode 的调试来启动。

现在访问localhost:3000就ok了。

async/await的使用

function getSyncTime() {
  return new Promise((resolve, reject) => {
    try {
      let startTime = new Date().getTime()
      setTimeout(() => {
        let endTime = new Date().getTime()
        let data = endTime - startTime
        resolve( data )
      }, 500)
    } catch ( err ) {
      reject( err )
    }
  })
}

async function getSyncData() {
  let time = await getSyncTime()
  let data = `endTime - startTime = ${time}`
  return data
}

async function getData() {
  let data = await getSyncData()
  console.log( data )
}

getData()

从例子中可以看出async/await的特点:

  • 可以让异步逻辑用同步写法实现。
  • 最底层的await返回还是需要是promise对象
  • 可以通过多层async function的同步写法来代替传统的callback嵌套

源码分析

├── lib
│   ├── application.js
│   ├── context.js
│   ├── request.js
│   └── response.js
└── package.json

这个就是github上https://github.com/koajs/koa/tree/v2.x开源的koa2源码的源文件结构,核心代码就是lib目录下的四个文件

  • application.js 是整个koa2的入口文件,封装了context。
  • content.js 处理应用上下文,里面直接封装了部分request.js和response.js的方法
  • request.js 处理http请求
  • response.js 处理http响应

常用的application方法:

app.use()
将给定的function当做中间件加载到应用中。
app.listen()
用于启动一个服务的快捷方法,以下范例代码在 3000 端口启动了一个空服务:

var koa = require('koa');
var app = koa();

app.listen(3000);

app.callback()
返回一个可被 http.createServer() 接受的程序实例,也可以将这个返回函数挂载在一个 Connect/Express 应用中。

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值