为啥vue中子路由点击router-link只能刷新一次子页面?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥vue中子路由点击router-link只能刷新一次子页面?相关的知识,希望对你有一定的参考价值。

主页面有一个区域用router-view显示子页面,绑定了一个子路由,使用router-link 显示该页面,点击router-link刷新子页面后导航栏地址也发生变化,变成子页面的url。然后如果在不切换url或者再刷新的情况下,再点击router-link就不能重新加载子页面了。这种情况应该怎么解决呢

参考技术A 在router-link使用时间戳.或者router-view增加一个v-show属性,点击时候快速切换一下.

VUE路由router-link和router.push用法

两者的区别

  使用router-link方式跳转,会在页面渲染的时候就加载对应的路由比起直接写的方式的优点:不管是h5的history还是hash模式,切换的时候很方便;会默认阻止浏览器的默认事件;写路径的时候不用写基路径了。

  $router.push("/myroute")跳转到对应的路径,可在页面中写对应的点击事件,然后执行对应的方法中写跳转,可在跳转前再写一些别的逻辑。

一、<router-link :to="...">
  to里的值可以是一个字符串路径,或者一个描述地址的对象。例如:

// 字符串
<router-link to="apple"> to apple</router-link>
// 对象
<router-link :to="{path:‘apple‘}"> to apple</router-link>
// 命名路由
<router-link :to="{name: ‘applename‘}"> to apple</router-link>
//直接路由带查询参数query,地址栏变成 /apple?color=red
<router-link :to="{path: ‘apple‘, query: {color: ‘red‘ }}"> to apple</router-link>
// 命名路由带查询参数query,地址栏变成/apple?color=red
<router-link :to="{name: ‘applename‘, query: {color: ‘red‘ }}"> to apple</router-link>
//直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略
<router-link :to="{path: ‘apple‘, params: { color: ‘red‘ }}"> to apple</router-link>
// 命名路由带路由参数params,地址栏是/apple/red
<router-link :to="{name: ‘applename‘, params: { color: ‘red‘ }}"> to apple</router-link>

  二、router.push(...)方法

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

// 字符串
router.push(‘apple‘)
// 对象
router.push({path:‘apple‘})
// 命名路由
router.push({name: ‘applename‘})
//直接路由带查询参数query,地址栏变成 /apple?color=red
router.push({path: ‘apple‘, query: {color: ‘red‘ }})
// 命名路由带查询参数query,地址栏变成/apple?color=red
router.push({name: ‘applename‘, query: {color: ‘red‘ }})
//直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略
router.push({path:‘applename‘, params:{ color: ‘red‘ }})
// 命名路由带路由参数params,地址栏是/apple/red
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

以上是关于为啥vue中子路由点击router-link只能刷新一次子页面?的主要内容,如果未能解决你的问题,请参考以下文章

Vue <router-link> 不可点击

vue router动态路由

Vue路由<router-link>属性的使用

VUE路由router-link和router.push用法

Vue直接URL不起作用,只有router-link点击

Vue 默认路由 与路由嵌套