Node KOA框架入门
KOA:
v1 generator
v2 过渡版 generator&async
v3 async/await
koa
koa不带路由 因此得cnpm i koa-router -D
路由:1.嵌套、2.参数
0.普通路由
const koa = require(‘koa‘); const Router = require(‘koa-router‘); let server = new koa(); server.listen(8520,()=>{console.log(‘success‘);}); //普通路由 let router = new Router(); router.get(‘/a‘, async ctx=>{ //ctx:上下文对象 ctx.body=‘aaa‘; ctx.body+=‘bbb‘; console.log(ctx.body); }) //把router怼给server才能生效 server.use(router.routes());
1.嵌套路由
//1.嵌套路由: /user /company /person /admin /news /sport /woman /man /car ...
(1).项目目录
(2).index.js
const Router = require(‘koa-router‘); let router = new Router(); router.get(‘/‘,async ctx=>{ ctx.body=‘用户‘; }) router.use(‘/company‘,require(‘./company‘)) router.use(‘/admin‘,require(‘./admin‘)) module.exports=router.routes();
(3).admin.js和company.js
const Router = require(‘koa-router‘); let router = new Router(); router.get(‘/a‘,async ctx=>{ ctx.body=‘管理员的a‘; }) module.exports=router.routes();
const Router = require(‘koa-router‘); let router = new Router(); router.get(‘/a‘,async ctx=>{ ctx.body=‘企业的a‘; }); module.exports=router.routes();
(4).server.js
let router = new Router(); router.use(‘/user‘,require(‘./routers/user‘)); server.use(router.routes());
运行node server.js,在浏览器输入"localhost:8520/user/admin/a",页面上则显示"管理员的a";
输入"localhost:8520/user/company/a",页面上则显示"企业的a"。
2.参数
//2.参数: http://localhost:8520/news/12 http://localhost:8520/news/123/889 http://localhost:8520/news/123/555/146 quretion1: 用?id=xxx传参和/:id的区别 urlencoded http://aaa.com/user?a=12&b=5 params http://aaa.com/user/12/5 urlencoded params 顺序灵活 顺序是死的 可以省略 不可省略的 不利于SEO 利于SEO(因为地址是静态的)
(1).项目目录
(2).参数params
const Koa = require(‘koa‘); const Router = require(‘koa-router‘); let server = new Koa(); server.listen(8520); let router = new Router(); router.get(‘/news/:id‘,async ctx=>{ console.log(ctx.params); let {id} = ctx.params ctx.body=`新闻${id}`; }); router.get(‘/news/:id/:id2‘,async ctx=>{ console.log(ctx.params); let {id,id2} = ctx.params ctx.body=`新闻${id}_${id2}`; }); router.get(‘/news/:id/:id2/:id3‘,async ctx=>{ console.log(ctx.params); let {id,id2,id3} = ctx.params ctx.body=`新闻${id}_${id2}_${id3}`; }); server.use(router.routes());
(3).参数urlencoded
const Koa = require(‘koa‘); const Router = require(‘koa-router‘); let server = new Koa(); server.listen(8520,()=>{console.log(‘success‘);}); let router = new Router(); router.get(‘/news/‘,async ctx=>{ console.log(ctx.query); let {id} = ctx.query; }); server.use(router.routes());
熟悉ctx对象
熟悉ctx对象 server.context:相当于ctx的prototype 所以server.context适合放全局的东西 ctx.request ctx.response 信息: ctx.method 请求方法 ctx.url 请求地址 ctx.path 请求路径 ctx.query get数据 ctx.ip 客户端ip ctx.headers 请求头
比较方便的报错方法
比较方便的报错方法: ctx.throw //报错并且退出 eg: if(!ctx.query.user || !ctx.query.pass){ ctx.throw(400,‘user and password is required‘) }else{ ctx.body=‘成功‘; } ctx.assert() //断言测试 ctx.assert(条件,code,msg)==if(!条件)ctx.throw eg: ctx.assert(ctx.query.user,400,‘username is required‘)
相关推荐
往后余生 2020-09-17
lzccheng 2020-09-06
苏莉koa 2020-01-29
80447704 2020-01-02
LorenLiu 2019-11-06
LorenLiu 2019-10-26
yanyongtao 2020-11-02
webgm 2020-08-16
lert0 2020-08-16
80447704 2020-06-09
LorenLiu 2020-06-07
无缘公子 2020-02-02
LorenLiu 2020-01-31
LorenLiu 2020-01-30
80447704 2020-01-30
Qimingweikun 2020-01-28
byourb 2020-01-04