vue 二次跳转同一页面,页面不刷新,跳转路径相同,参数不同,页面不刷新问题解决方法

原因

路由切换,组件并没有被卸载,而是被隐藏了,那么要让vue更新组件,要么卸载组件重新渲染,要么让组件的key发生变化,当组件的key变化时就会触发组件重新渲染。

1、根本解决办法

全局搜索router-view,找到该标签,给该标签加上key,一般该标签都在App.vue文件里

<router-view :key="route.fullPath"/>

如果是后台管理系统,一般会有个layout文件夹,负责后台管理系统页面主要的布局,如果有找到下面类似的标签,也可以在component标签里加key,也是同样的效果

<keep-alive :include="tagsViewStore.cachedViews">
    <component v-if="!route.meta.link" :is="Component" :key="route.fullPath"/>
</keep-alive>

2、其他解决方法

(如果是在后台管理系统中使用,以下方法不是很推荐,因为你需要在每个不刷新的页面去写同样的代码,只推荐上面的方法)

1、activated函数(组件激活时调用的函数)
activated(){
    // 要执行更新的代码  
},

2、watch,监听路由

watch: {
	'$route' (to, from) {
         // 要执行更新的代码
	}
},
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值