欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 产业 > vue 前进刷新后退不刷新

vue 前进刷新后退不刷新

2024/10/25 2:19:01 来源:https://blog.csdn.net/genius_yym/article/details/141683778  浏览:    关键词:vue 前进刷新后退不刷新

本篇主要讲述vue如何通过路由实现“前进刷新后退不刷新”功能。

1. 在App.vue中配置keep-alive

// <router-view></router-view> 外添加<template><div id="app"><!-- 前进后退都刷新 --><!-- <router-view></router-view> --><keep-alive><!-- 这里是会被缓存的视图组件 --><router-view v-if="$route.meta.keepAlive"></router-view></keep-alive><!-- 这里是不被缓存的视图组件 --><router-view v-if="!$route.meta.keepAlive"></router-view></div>
</template>

2. 配置router路由,即meta对象中添加keepAlive属性

{path: '/add/addInfo',name: "addInfo",component: resolve => require(["../page/add/addInfo.vue"], resolve),meta: {keepAlive: false, //此组件不需要被缓存}
},
{path: '/add/jtinfo',name: "jtinfo",component: resolve => require(["../page/add/jtinfo.vue"], resolve),meta: {keepAlive: true, //此组件需要被缓存sBack: false,}
},

3.在需要缓存的页面配置

  data(){return {isFirstEnter: false, // 是否第一次进入,默认falsedatas: [], //页面的数据}},created() {// 只有第一次进入或者刷新页面后才会执行此钩子函数// 使用keep-alive后(2+次)进入不会再执行此钩子函数this.isFirstEnter=true;},activated() {if(!this.$route.meta.isBack || this.isFirstEnter){// 如果isBack是false,表明需要获取新数据,否则就不再请求,直接使用缓存的数据// 如果isFirstEnter是true,表明是第一次进入此页面或用户刷新了页面,需获取新数据this.datas=''// 把数据清空,可以稍微避免让用户看到之前缓存的数据// 执行了 mounted 中的事件/*this.loaGongkeInfoSearck()this.TabSwitch(0);this.heightM = document.body.scrollHeight;*/}// 恢复成默认的false,避免isBack一直是true,导致下次无法获取数据this.$route.meta.isBack=false// 恢复成默认的false,避免isBack一直是true,导致每次都获取新数据this.isFirstEnter=false;},beforeRouteEnter(to, from, next) {// 路由导航钩子,此时还不能获取组件实例 `this`,所以无法在data中定义变量(利用vm除外)// 参考 https://router.vuejs.org/zh-cn/advanced/navigation-guards.html// 所以,利用路由元信息中的meta字段设置变量,方便在各个位置获取。这就是为什么在meta中定义isBack// 参考 https://router.vuejs.org/zh-cn/advanced/meta.htmlif(from.name=='addInfo'){ //from.name即是路由里面的name属性值,即路径//判断是从哪个路由过来的to.meta.isBack=true; // 该路由过来当前页面 不需要刷新 获取新数据,直接用之前缓存的数据即可}if(from.name=='jtinfo'){to.meta.isBack=false;// 该路由过来当前页面 需要刷新 获取新数据}next();},

看看代码注释吧,应该不难理解。
这算是一种比较古老的实现方式了。
最后:大吉大利,祝你没BUG。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com