【vue2新增页面跳转列表页,当前页面不会刷新问题,有效果的点个赞嗷】

概要

开发中遇到的罕有需求,一般来说切换路由页面就会重新渲染,相应接口也会自动刷新。但是有些需求新增页面是走路由的,关闭心中页会关闭当前面包屑,返回上一个,所以这时候由于之前列表页的面包屑一直存在,当前页面数据不会刷新

案例

如图:新增页面保存成功/关闭后返回列表页,当前是直接关闭新增页面的面包屑实现,所以遇到列表页数据不刷新问题,尤其新增后效果最明显。
在这里插入图片描述

解决方法

直接上代码,在需要刷新的页面直接加上这段代码。

data(){
	return {
	  		//定义变量保存上一个路由的路径
	         previousRoutePath:'上一个路由的路径'
			}  
    },
watch: {
    $route(to, from) {
        if (to.path === this.previousRoutePath) {
            // 在这里调用查询页面方法
            this.fetchData(); // 假设fetchData是获取数据的方法
        }
        this.previousRoutePath = from.path;
    }
},

小结

  • $route是Vue.js内置的路由对象,watch会监视它的变化。

  • 当路由发生变化时,会触发$route对象的变化,从而执行watch中定义的逻辑。

  • 在逻辑中,通过比较当前路由的to.path和之前路由的this.previousRoutePath来确定是否需要调用查询页面方法。

  • 如果当前路径与之前路径相同,即路由未发生变化,就调用fetchData()方法重新获取数据。

  • 最后,将当前路由的路径赋值给this.previousRoutePath,以便下一次路由变化时进行比较。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端小百科

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值