【js全栈】- koa2-路由koa-router

你不能撒谎,撒谎这个东西你一开始就停不下来了。

简洁是智慧的灵魂,冗长是肤浅的藻饰 --《哈姆莱特》

书接上回koa2安装,在koas的项目中我们开启了服务,看见了hello,world。在后端的开发实际中,这些是不够的。不急,跟着文章走,不能保证你精通,但绝对够你入门。

本文收录于:js全栈工程师

理解:在我肤浅的开发之中。路由管理,大部分是接收不同的api请求,返回数据的。例如一个 api/user的请求,发送过来账号,md5加密后的密码,我们把路由带进来的参数与数据库比对,给出相应的返回。

  • 安装路由管理插件
npm install koa-router -s

在webstom中的命令行中键入命令即可

  • 编辑路由文件

后端的复杂,大抵就是不知道业务会拓展到什么状况,功能多么复杂。因此这里我们使用文件夹来管理。

目录是 ./router/index

const router = require('koa-router')();   //引入路由函数

router.get('/',async(ctx,next)=>{
    "use strict";
    ctx.redirect('/index')
})
// 路由中间,页面路由到/,就是端口号的时候,(网址),页面指引到/index


router.get('/index',async(ctx,next)=>{
    "use strict";
    let html = `
            <h1>请你使用post来获取json</h1>
            <form action="/api" method="post">
                <input type="text" name="name" >
                <input type="text" name="ages">
                <button type="submit">提交</button>
            </form>
        `
    ctx.body= html
})
//在index的路由的时候返回一段html,(实际开发中,不会这样做的) 页面是一个表单,模拟我们的前端或者移动
// 操作动作,(记住,这是动作。后面的redux中是很重要的一部分)提交数据到/api的路由中

router.post('/api',async(ctx, next) => {
    let apps = ctx.request.body
    console.log(ctx.request.body )
    ctx.body = '111111'
})
//页面路由到api的时候,
//  ctx.redirect.body及时之前提交表单的数据
// ctx.body就是页面的返回体,之前说过了,这里赋值是什么,就返回什么。

module.exports = router
//将页面暴露出去

还有app .js编辑

const Koa = require('koa')   //koa2中间件依赖
const app = new Koa()       //js的继承
const Router = require('koa-router')  //路由依赖的中间间

// app.use( async ( ctx ) => {
//     ctx.body = 'hello world'
// })                           //koa2中间件,使用路由的(使用路由后,这里就不会在编辑代码了)


app.use(require('./router/index').routes())

app.listen(3000)            //服务启动端口
console.log('启动成功')      //日志打印

执行代码效果


路由到index页面

点击提交后。


路由到api页面

页面也能路由到api页面了。但是,我们要获取的是表单内提交的数据。而不是11111。(这里有个坑,自己爬....)还差一个插件,这就是kao2我认为的一个好处,按需使用。灵巧,便捷。


  • koa-bodyparser 上下文解析插件
    安装命令
npm install koa-bodyparser -s

app.js项目入口文件使用。

const Koa = require('koa')   //koa2中间件依赖
const app = new Koa()       //js的继承
const Router = require('koa-router')  //路由依赖的中间间
const bodyParser = require('koa-bodyparser')  //请求体,返回体解析类似json,text,图片等
// app.use( async ( ctx ) => {
//     ctx.body = 'hello world'
// })                           //koa2中间件,使用路由的(使用路由后,这里就不会在编辑代码了)

app.use(bodyParser())    //使用解析上下文插件

app.use(require('./router/index').routes())

app.listen(3000)            //服务启动端口
console.log('启动成功')      //日志打印

路由页面修改

const router = require('koa-router')();   //引入路由函数

router.get('/',async(ctx,next)=>{
    "use strict";
    ctx.redirect('/index')
})
// 路由中间间,页面路由到/,就是端口号的时候,(网址),页面指引到/index


router.get('/index',async(ctx,next)=>{
    "use strict";
    let html = `
            <h1>请你使用post来获取json</h1>
            <form action="/api" method="post">
                <input type="text" name="name" >
                <input type="text" name="ages">
                <button type="submit">提交</button>
            </form>
        `
    ctx.body= html
})
//在index的路由的时候返回一段html,(实际开发中,不会这样做的) 页面是一个表单,模拟我们的前端或者移动
// 操作动作,(记住,这是动作。后面的redux中是很重要的一部分)提交数据到/api的路由中

router.post('/api',async(ctx, next) => {
    let apps = ctx.request.body
    console.log(ctx.request.body )
    ctx.body = apps
})
//页面路由到api的时候,
//  ctx.redirect.body及时之前提交表单的数据
// ctx.body就是页面的返回体,之前说过了,这里赋值是什么,就返回什么。

module.exports = router
//将页面暴露出去
  • 重启项目

这里输入数据,点击提交。


index路由页面

页面返回你输入的数据,即表示路由成功


api路由页面

还是那句话,或看官网api,对于学习koa回更好。

koa官网

总结
在实际的开发中,后端只是返回不同的json,路由只是对应的返回数据。koa-bodyparser插件的作用来解析请求题的参数,json,图片,文件什么的。后期会有详细的讲解。这里了解一下就好。

是不是觉得后端也不难,那就对了,我们不要急,循序渐进的学习koa。
后端之中,数据库是很关键的一点。我更新慢,因为事多,(最近写小程序)。建议去看看数据库,mysql。我也有写了一篇,3000多字,关键我觉得垃圾。但以我的尿性,肯定是推翻重来的。

关注我,下章讲静态资源管理,彻彻底底的前后端分离开发。

我爱你,就像星星爱着月亮。感谢你们的点赞与关注

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,364评论 25 707
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,579评论 18 139
  • 框架提出的背景 ES6/7带来的变革 自ES6确定和ES7中async/await开始普及,Node的发展变得更加...
    宫若石阅读 8,477评论 1 14
  • 《 圈子圈套1 》读后感 内容概要 : 虽然没有硝烟,却比战场更血腥;虽然并未战死,却比死亡更痛苦...
    玲儿妹妹阅读 264评论 0 0
  • 我好喜欢你 只是 你在哪里 我好想你 你快出来 好不好
    烤鱼咯阅读 142评论 0 2