nodejs框架Koa2探秘v1.0

简介: nodejs框架Koa2初探nodejs基础(参考菜鸟教程的nodejs教程 )JavaScript语法创建服务器模块http文件读取模块fs路径path模块系统 require、module.

nodejs框架Koa2初探

nodejs基础(参考菜鸟教程的nodejs教程 )

  1. JavaScript语法
  2. 创建服务器模块http
  3. 文件读取模块fs
  4. 路径path
  5. 模块系统 require、module.exports
  6. es6语法(新版本的nodejs除了模块外全部支持

nodejs框架-express

文档地址:http://www.expressjs.com.cn/

nodejs框架-koa

中文文档地址:https://koa.bootcss.com/
node模块仓库地址:https://www.npmjs.com/

1、初始化package.json

新建目录koademo,执行 npm init,一路回车

2、创建一个简单的koa应用(hello world)
安装koa模块 npm install koa --save
在项目根目录新建app.js,app.js代码如下:

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

app.use(async ctx => {
  ctx.body = 'Hello World';
});

app.listen(3000);

执行node app.js
用浏览器访问 http://localhost:3000

3、koa路由,使用koa-simple-router

https://www.npmjs.com/package/koa-simple-router
安装 koa-simple-router模块,然后修改上面的app.js代码,变成下面这个样子

const Koa = require('koa')
const router = require('koa-simple-router')
const app = new Koa()
 
app.use(router(_ => {
  _.get('/', (ctx, next) => {
    ctx.body = 'hello world';
  })
  _.post('/path', (ctx, next) => {
 
  })
  // 同时支持get和post请求
  _.all('/login', (ctx, next) => {
    ctx.body = {
        code: 666,
        msg: '登录成功'
    }
  })
  _.all('/regester', (ctx, next) => {
    ctx.body = {
        code: 666,
        msg: '注册成功'
    }
  })
}))

app.listen(3000,()=>{
    console.log('服务已启动,在 http://localhost:3000/');
});

重启服务,用浏览器访问 
http://localhost:3000/login 和
http://localhost:3000/register

为了让代码结构性更好,我们可以把路由这部分单独放在一个文件里

4、supervisor 服务器自动重启模块

我们发现没修改一次代码,都必须重启才能生效,这显然不方便,supervisor模块就可以解决这个问题
使用supervisor我们需要这样

  1. 全局安装supervisor npm i supervisor -g
  2. 启动服务的时候用supervisor app.js代替node app.js
6、设置静态目录

在目录中创建目录static,在static下创建文件demo.html,访问http://localhost:3000/static/demo.html是无法访问得到,因为我们还没有设置静态资源目录
设置静态资源目录要用到koa-static模块
安装koa-static npm i koa-static --save
在app.j是里加入如下代码

const serv = require('koa-static');
app.use(serv(__dirname + '/static'));

再来访问 http://localhost:3000/static/demo.html,就可以访问了

7、获取请求参数

给刚才的demo.html添加jquery用来发送请求,然后在demo里添加如下代码:

 var url = 'http://localhost:3000/login';
var data = {
    username: 'laohu',
    phone: '15013795539'
}
$.ajax({
    url,
    data,
    type: 'get',
    dataType: 'json',
    success: function(res) {
        console.log(res);
    },
    error: function() {
        console.log('请求失败');
    }
})
  1. 获取get请求参数
    在router.js的login接口里加入如下代码
// 获取get请求参数
const username = ctx.query.username;
const phone = ctx.query.phone;
并把username和phone放入ctx.body

2.获取post请求
获取post请求需要使用koa-body模块
安装koa-body npm i koa-body --save
在app.js里加入如下代码:

const koaBody = require('koa-body');
app.use(koaBody());

获取post请求参数的代码如下

ctx.request.body.xxx
8、模板

一般请求一个接口返回的是一坨数据,然而有时候我们希望返回的是一个html网页或者一段html代码(上周分享的服务器渲染)
我们试用koa-swig模块来向前端返回一个html
安装koa-swig npm i koa-swig

  • 在根目录创建views目录,在views目录下创建tpl.html
  • 在app.js添加如下代码:
const render = require('koa-swig')
const co = require('co')
app.context.render = co.wrap(render({ 
    root: './views', 
    autoescape: true,
    cache: 'memory', 
    writeBody: false, 
    ext: 'html' }))
    
// 在router.js里面的根路由修改成下面这样,同时给模板传递变量msg
_.get('/', async (ctx, next) => {
    ctx.body = await ctx.render('tpl', { msg: 'hello' });
})
  • 在tpl.html里面添加代码:
<p>{{msg}}</p>
  • 访问 http://localhost:3000,就可以看到一个html页面
  • 可以使用axios请求后台接口,然后渲染页面,最后返回给前端(详情请看github上的demo)
9、相关地址

本文github地址:https://github.com/wotu-courses/koa2

本文相关nodejs项目地址: https://github.com/wotu-courses/zhihu_server.git

目录
相关文章
|
4月前
|
存储 JavaScript 数据库
nodejs中express框架实现增删改查接口
nodejs中express框架实现增删改查接口
|
5月前
|
开发框架 JSON JavaScript
Node.js教程-express框架
Node.js教程-express框架
39 1
|
8月前
|
JSON JavaScript 中间件
node.js中Express框架路由,中间件
node.js中Express框架路由,中间件
|
8月前
|
域名解析 监控 JavaScript
宝塔面板pm2管理器部署node.js(express框架)sever文件,可以使用域名访问你的后端项目
宝塔面板pm2管理器部署node.js(express框架)sever文件,可以使用域名访问你的后端项目
467 0
|
3天前
|
开发框架 JavaScript 中间件
深入探索Node.js的Express框架:使用与中间件详解
【4月更文挑战第30天】本文深入探讨了Node.js的Express框架,介绍了其作为Web开发的强大工具,主要聚焦于基本使用和中间件。Express是基于Node.js的Web应用框架,用于构建高效的应用和API。文章详细讲解了如何安装Express,创建简单应用,以及中间件的工作原理和应用,包括中间件的顺序、错误处理和挂载位置。此外,还提到了使用第三方中间件扩展功能。理解Express基础和中间件对于开发高质量Web应用至关重要。
|
21天前
|
开发框架 JavaScript 前端开发
【Node系列】Express 框架
Express.js 是一个基于 Node.js 平台的极简、灵活的 web 应用开发框架,提供一系列强大的特性来帮助你创建各种 web 和移动设备应用。
35 2
|
7月前
|
JavaScript 前端开发 架构师
Node框架 【Egg-企业级框架】
Node框架 【Egg-企业级框架】
165 0
|
3月前
|
开发框架 JavaScript 前端开发
比较两个突出的node.js框架:koa和express
接上文讲述了 koa框架,这边文章比较一下这两个突出的node.js框架:koa和express
|
4月前
|
JavaScript 前端开发 NoSQL
2022 年值得使用的 Node.js 框架
2022 年值得使用的 Node.js 框架
|
9月前
|
JavaScript Shell Linux
Node.js中的express框架,修改内容后自动更新(免重启),express热更新
Node.js中的express框架,修改内容后自动更新(免重启),express热更新