https://www.cnblogs.com/xzybk/p/11736931.html

to里的值可以是一个字符串路径,或者一个描述地址的对象。例如:

  1. // 字符串
  2. <router-link to="apple"> to apple</router-link>
  3. // 对象
  4. <router-link :to="{path:'apple'}"> to apple</router-link>
  5. // 命名路由
  6. <router-link :to="{name: 'applename'}"> to apple</router-link>
  7. //直接路由带查询参数query,地址栏变成 /apple?color=red
  8. <router-link :to="{path: 'apple', query: {color: 'red' }}"> to apple</router-link>
  9. // 命名路由带查询参数query,地址栏变成/apple?color=red
  10. <router-link :to="{name: 'applename', query: {color: 'red' }}"> to apple</router-link>
  11. //直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略
  12. <router-link :to="{path: 'apple', params: { color: 'red' }}"> to apple</router-link>
  13. // 命名路由带路由参数params,地址栏是/apple/red
  14. <router-link :to="{name: 'applename', params: { color: 'red' }}"> to apple</router-link>

router.push(…)方法

同样的规则也适用于router.push(…)方法。

  1. // 字符串
  2. router.push('apple')
  3. // 对象
  4. router.push({path:'apple'})
  5. // 命名路由
  6. router.push({name: 'applename'})
  7. //直接路由带查询参数query,地址栏变成 /apple?color=red
  8. router.push({path: 'apple', query: {color: 'red' }})
  9. // 命名路由带查询参数query,地址栏变成/apple?color=red
  10. router.push({name: 'applename', query: {color: 'red' }})
  11. //直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略
  12. router.push({path:'applename', params:{ color: 'red' }})
  13. // 命名路由带路由参数params,地址栏是/apple/red
  14. router.push({name:'applename', params:{ color: 'red' }})

注意点

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

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

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

带路由参数params时,路由map里的path应该写成: path:’/apple/:color’ ;
带查询参数query时,路由map里的path应该写成: path:’/apple’ ;

3.获取参数方法:

在组件中: {{$route.params.color}}
在js里: this.$route.params.color