动态路由匹配

动态路由的概念

动态路由是指:把Hash地址中可变的部分定义为参数项,从而提高路由规则的复用性。
在vue-router中使用英文冒号(:)来定义路由规则的参数项。示例代码如下:

{path:'/movie/:id',component:Movie}
//将以下三个路由规则合并为一个,提高了路由的复用性
{path:'/movie/1',component:Movie}
{path:'/movie/2',component:Movie}
{path:'/movie/3',component:Movie}

举例:
路由规则:

 // 需求:在 Movie 组件中,希望根据 id 的值,展示对应电影的详情信息
    // 可以为路由规则开启 props 传参,从而方便的拿到动态参数的值
    //使用:来声明参数,参数名自取,在movie组件中,mid为props匹配的参数名
    //动态参数项使用参数值
    //this._routerRoot._route.params.mid拿到当前的mid值
  
    //this._routerRoot._route是路由的参数对象
     //this._routerRoot._route是路由的导航对象
    { path: '/movie/:mid', component: Movie},
     <router-link to="/movie/1">洛基</router-link>
    <router-link to="/movie/2">雷神</router-link>
    <router-link to="/movie/3">复联</router-link>
//在组件中定义props数组
  // 接收 props 数据
  props: ['mid'],
//在router中
  //可以为路由规则开启props传参,从而方便的拿到动态参数的值
   { path: '/movie/:mid', component: Movie, props: true },


<!-- 注意:在 hash 地址中,? 后面的参数项,叫做“查询参数” -->
 //在路由”参数对象“中,需要使用this._routerRoot._route.params来访问路径参数
    <!-- 在路由“参数对象”中,需要使用 this.$route.query 来访问查询参数 -->

    <!-- 注意:在 this.$route 中,path 只是路径部分;fullPath 是完整的地址 -->
    <!-- 例如: -->
    <!-- /movie/2?name=zs&age=20 是 fullPath 的值 -->
    <!-- /movie/2 是 path 的值 -->
    <router-link to="/movie/1">洛基</router-link>
    <router-link to="/movie/2?name=zs&age=20">雷神</router-link>
    <router-link to="/movie/3">复联</router-link>


fullpath和path
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值