vue3路由中绑定和获取参数

Javascript piniu 929浏览 0评论

一、vue路由设置路由参数有2种方式:

1.通过query配置:

<router-link :to="{ name:'user',query:{id:1002} }">查询</router-link>

通过query配置参数路由,url显示如下:
http://127.0.0.1/user?id=1002

2.通过params配置:

<router-link :to="{ name:'book',params:{id:1003} }">查询</router-link>

通过query配置参数路由,url显示如下:
http://127.0.0.1/book/1003

通过params配置的参数,需要在配置路由的时候给参数预留占位符,如下图:

二、获取路由参数的方法:

1.通过query配置的:

this.$route.query

2.通过params配置的:

this.$route.params

补充说明:
$route:路由信息对象,只读对象;
$router:路由操作对象 ,只写对象。

使用router-link 生成路由链接的示例

<router-link to="user"> 查询明细</router-link>
//字符串

<router-link :to="{path:'user'}"> 查询明细</router-link>
//对象

<router-link :to="{name: 'userInfo'}"> 查询明细</router-link>
//命名路由

<router-link :to="{path: 'user', query: {username: 'xiaoming' }}"> 查询明细</router-link>
//直接路由带查询参数query,地址栏变成 /user?username=xiaoming

<router-link :to="{name: 'userInfo', query: {username: 'xiaoming' }}"> 查询明细</router-link>
//命名路由带查询参数query,地址栏变成/user?username=xiaoming

<router-link :to="{path: 'user', params: { username: 'xiaoming' }}"> 查询明细</router-link>
//直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略

<router-link :to="{name: 'userInfo', params: { username: 'xiaoming' }}"> 查询明细</router-link>
//命名路由带路由参数params,地址栏是/user/xiaoming

使用$router的push方法建立路由链接的示例

this.$router.push('user')
//传字符串

this.$router.push({path:'user'})
//传对象

this.$router.push({name: 'userInfo'})
//命名路由

this.$router.push({path: 'user', query: {username: '张三' }})
//直接路由带查询参数query,地址栏变成 /user?username=张三

this.$router.push({name: 'userInfo', query: {username: '张三' }})
// 命名路由带查询参数query,地址栏变成/user?username=张三

this.$router.push({path:'user', params:{ username: '张三' }})
//直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略

this.$router.push({name:'username', params:{ username: '张三' }})
// 命名路由带路由参数params,地址栏是/user/张三

1、关于带参数的路由总结如下:

无论是直接路由“path” 还是命名路由“name”,带查询参数query,地址栏会变成“/url?参数名=参数值“;
直接路由“path” 带路由参数params , params 不生效;
命名路由“name” 带路由参数params , 地址栏保持是“/url/参数值”;

2、设置路由map里的path值:

带路由参数params时,路由map里的path应该写成: path:’/user/:uid‘; 的形式
带查询参数query时,路由map里的path应该写成: path:’/user’;


发表我的评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • * 昵称:
  • * 邮箱: