node.js之框架

选用哪种框架

框架的学习说起来只是选择一种通用工具吧,是帮助你快速搭建应用的一把武器,可对于武器而言,没有用上百八十天的根本就很难知道是否真的就趁手,然而真正精通十八般武艺的人几乎没有,我们能做的只是选择一个评价稍微高一点的用的人又比较多的框架来当我们的武器

这里直接转载廖雪峰教程中的一部分

koa是Express的下一代基于Node.js的web框架,目前有1.x和2.0两个版本。

历史

  1. Express

Express是第一代最流行的web框架,它对Node.js的http进行了封装,用起来如下:

var express = require(‘express’);
var app = express();

app.get(‘/’, function (req, res) {
res.send(‘Hello World!’);
});

app.listen(3000, function () {
console.log(‘Example app listening on port 3000!’);
});
虽然Express的API很简单,但是它是基于ES5的语法,要实现异步代码,只有一个方法:回调。如果异步嵌套层次过多,代码写起来就非常难看:

app.get(‘/test’, function (req, res) {
fs.readFile(‘/file1’, function (err, data) {
if (err) {
res.status(500).send(‘read file1 error’);
}
fs.readFile(‘/file2’, function (err, data) {
if (err) {
res.status(500).send(‘read file2 error’);
}
res.type(‘text/plain’);
res.send(data);
});
});
});
虽然可以用async这样的库来组织异步代码,但是用回调写异步实在是太痛苦了!

  1. koa 1.0

随着新版Node.js开始支持ES6,Express的团队又基于ES6的generator重新编写了下一代web框架koa。和Express相比,koa 1.0使用generator实现异步,代码看起来像同步的:

var koa = require(‘koa’);
var app = koa();

app.use(‘/test’, function *() {
yield doReadFile1();
var data = yield doReadFile2();
this.body = data;
});

app.listen(3000);
用generator实现异步比回调简单了不少,但是generator的本意并不是异步。Promise才是为异步设计的,但是Promise的写法……想想就复杂。为了简化异步代码,ES7(目前是草案,还没有发布)引入了新的关键字async和await,可以轻松地把一个function变为异步模式:

async function () {
var data = await fs.read(‘/file1’);
}
这是JavaScript未来标准的异步代码,非常简洁,并且易于使用。

  1. koa2

koa团队并没有止步于koa 1.0,他们非常超前地基于ES7开发了koa2,和koa 1相比,koa2完全使用Promise并配合async来实现异步。

koa2的代码看上去像这样:

app.use(async (ctx, next) => {
await next();
var data = await doReadFile();
ctx.response.type = ‘text/plain’;
ctx.response.body = data;
});

出于兼容性考虑,目前koa 2仍支持generator的写法,但下一个版本将会去掉。

选择哪个版本?

目前JavaScript处于高速进化中,ES7是大势所趋。为了紧跟时代潮流,教程将使用最新的koa 2开发!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值