koa-router 路由参数与前端路由的结合
2019-05-18 23:40
3299 查看
koa-router 定制路由时支持通过冒号形式在 url 中指定参数,该参数会挂载到 context上然后可通过 context.params.paramName方便地获取。 考察下面的示例: var Koa = require("koa"); var Router = require("koa-router"); var app = new Koa(); var router = new Router(); router.get("/user/:id", async function(ctx, next) { const userId = ctx.params.id; ctx.body = `user id is:${userId}`; }); app.use(router.routes()).use(router.allowedMethods()); app.listen(3000); console.log("server started at http:localhost:3000"); 启动服务后可看到页面中展示出了从 url 中获取到的 id 参数。 路由参数的获取展示 现在来考虑另一种情况,即路由中支持前端路由的情况。 即把现在的 url 由 /user/:id的形式扩展成 /user/:id/foo/bar,这里 /foo/bar部分可以是任何路由,作为前端处理的路由部分。 为了实现这样的前端路由部分,服务端路由的配置需要借助正则来进行, - router.get("/user/:id", async function(ctx, next) { + router.get(["/user/:id", /\/user\/([\w|\d]+)\/.*/], async function(ctx, next) { const userId = ctx.params.id; ctx.body = `user id is:${userId}`; }); 这里将路由中 url 由单个字符串变成了数组形式,第一个还是原来的路由,这样正常的通过 /user/1形式过来的页面能命中该路由。同时添加 /\/user\/([\w|\d]+)\/.*/部分,因为正则情况下不再支持路由中通过冒号进行参数的配置,所以这里 /user/后跟随的 id 也需要使用正则来替换掉。 但正则匹配下的路由就不能通过 context.params来访问 url 上的参数了。不过好在可通过在正则中定义匹配组(Capturing Groups)的形式来定义参数,即其中 ([\w|\d]+)括号包裹的部分,称为一个匹配组,一个匹配组是会自动被挂载到 context.params上的,只是不像通过冒号定义的参数那样会有一个名字,这种形式的参数按照匹配到的顺序形成一个数组赋值到 context.params,所以访问第一个匹配组形成的参数可通过 context.params[0]来获取。 于是上面的代码稍加修正后,就能够正确处理来自命名参数(通过冒号匹配)或正则参数形成的 query 参数了。 - router.get("/user/:id", async function(ctx, next) { + router.get(["/user/:id", /\/user\/([\w|\d]+)\/.*/], async function(ctx, next) { - const userId = ctx.params.id; + const userId = ctx.params.id || ctx.params[0]; ctx.body = `user id is:${userId}`; }); 最后完整的代码会是这样: var Koa = require("koa"); var Router = require("koa-router"); var app = new Koa(); var router = new Router(); router.get(["/user/:id", /\/user\/([\w|\d]+)\/.*/], async function(ctx, next) { const userId = ctx.params.id || ctx.params[0]; ctx.body = `user id is:${userId}`; }); app.use(router.routes()).use(router.allowedMethods()); app.listen(3000); console.log("server started at http:localhost:3000"); 此时访问以下连接进行测试, 均能正确命中页面并成功获取到路由中的参数。 正则路由及路由参数的获取 |
相关文章推荐
- koa-router中路由/后面不填参数就会报404的解决办法
- Vue.js结合vue-router和webpack编写单页路由项目
- angular4.0在路由Router时传递参数、获取参数的最灵活、阅读性最好的写法。
- 浏览器截取查询参数,后台路由和前端路由的俩种方式
- angular ui.router 路由传参数
- router路由跳转使用query传递参数刷新后数据无法获取
- 前端框架Aurelia —— 路由Router
- [转载]从源码的角度分析vue-router前端路由两种实现方式
- 浅谈vue-router2路由参数注意的问题
- 前端路由实现与 react-router 源码分析
- vue-router--路由传参结合请求数据(页面底部按钮跳转功能实现参考)
- Router路由笔记--传数据(前端工作)
- 关于react-router4中路由的配置,传参,跳转,可选参数写法
- ReactJs Router 路由地址跳转方式带参数
- vue-router中定义动态路由、嵌套路由,并动态获取参数
- 理解koa-router 路由一般使用
- vue通过 vue.mixin(混合)实现 任意页面记录滚动条位置(路由router.query参数一致) 并跳转到上次的位置
- koa-router 路由优先级问题
- iKcamp团队制作|基于Koa2搭建Node.js实战(含视频)☞ 路由koa-router
- Vue中的 this.$router.push() 参数获取 (通过路由传参)