场景:项目中遇到 vue 点击回退 从A页跳到B页,缓存A页,当B页状态修改再次返回A时,A页查询条件缓存不刷新,列表刷新
A页:

B页:

解决方法:
利用keep-alive 缓存需要缓存的页面

1.在app.vue中改写router-view

<template><div id="app"><keep-alive><router-view v-if="$route.meta.keepAlive"><!-- 这里是会被缓存的视图组件,比如 page1,page2 --></router-view></keep-alive><router-view v-if="!$route.meta.keepAlive"><!-- 这里是不被缓存的视图组件,比如 page3 --></router-view></div>
</template>

2.在router/index.js中添加路由元信息,设置需要缓存的页面
keepAlive:设置需要缓存的页面
isBack:通过beforeRouteEnter这个钩子函数中的from参数判断是从哪个页面过来的,这个参数执行时,组件实例还没创建,不能在data中定义变量。所以我们可以在路由中定义一个变量isBack,用来判断。

{path: '/trade',name: 'trade',component: () => import( /* webpackChunkName: "about" */ '@/views/trade.vue'),meta: {title:'trade.tradeTitle',keepAlive: true, // 此组件需要被缓存isBack:false, //用于判断上一个页面是哪个}},{path: '/detail/:id',name: 'detail',component: () => import( /* webpackChunkName: "about" */ '@/views/detail.vue'),meta: {title:'trade.detailTitle',keepAlive: false,isBack:false,//用于判断上一个页面是哪个}},

钩子函数的执行顺序:
不使用keep-alive
beforeRouteEnter --> created --> mounted --> destroyed
使用keep-alive
beforeRouteEnter --> created --> mounted --> activated --> deactivated
再次进入缓存的页面,只会触发beforeRouteEnter -->activated --> deactivated 。created和mounted不会再执行。我们可以利用不同的钩子函数,做不同的事。务必理解上述钩子函数的执行时机和执行顺序,本教程的核心就依赖于此钩子函数
activated和deactivated是使用keep-alive后,vue中比较重要的两个钩子函数,建议详细了解下。

  1. 在A页面中通过beforeRouteEnter这个钩子函数中判断是从哪个页面过来的
 beforeRouteLeave(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.path === '/detail'){//判断是从哪个路由过来的,//如果是B页面即detail页面过来的,表明当前页面不需要刷新获取新数据,直接用之前缓存的数据即可to.meta.isBack = true;}else{to.meta.isBack = false;}next();},
  1. data中定义变量isFirstEnter用来判断是否第一次进入,或是否刷新了页面,默认false
 data() {return {isFirstEnter:false,};},
  1. created中把isFirstEnter变为true,说明是第一次进入或刷新了页面
 created() {this.isFirstEnter=true;// 只有第一次进入或者刷新页面后才会执行此钩子函数// 使用keep-alive后(2+次)进入不会再执行此钩子函数this.$nextTick(() => {this.getLists();});},
  1. activated中增加判断条件
activated() {if(this.$route.meta.isBack || !this.isFirstEnter){// 如果isBack是false,表明需要获取新数据,否则就不再请求,直接使用缓存的数据// 如果isFirstEnter是true,表明是第一次进入此页面或用户刷新了页面,需获取新数据this.tradeList=[]this.AjaxList = []     //把数据清空,可以稍微避免让用户看到之前缓存的数据this.pageNum = 1;this.$nextTick(() => {this.getLists();});}else{this.$route.meta.isBack=falsethis.isFirstEnter=false;}
},

vue单页面 回退页面 keeplive 缓存问题相关推荐

  1. vue index.html 缓存,解决vue单页面 回退页面 keeplive 缓存问题

    场景:项目中遇到 vue 点击回退 从A页跳到B页,缓存A页,当B页状态修改再次返回A时,A页查询条件缓存不刷新,列表刷新 A页: B页: 解决方法: 利用keep-alive 缓存需要缓存的页面 1 ...

  2. app怎么嵌套vue页面_app内嵌vue单页面应用的一些坑

    写这篇文章的原因是想总结一下自己最近开发的一个内嵌app的vue单页面项目,看看有哪些坑!!! 1.白屏 项目第一次上线正常 项目第二次上线,20多个用户反馈白屏(没见过这世面,心里慌的不行!!!), ...

  3. Nginx 解决WebApi跨域二次请求以及Vue单页面问题

    Nginx 解决WebApi跨域二次请求以及Vue单页面问题 参考文章: (1)Nginx 解决WebApi跨域二次请求以及Vue单页面问题 (2)https://www.cnblogs.com/ji ...

  4. nginx配置解决vue单页面打包文件大,首次加载慢的问题

    nginx配置解决vue单页面打包文件大,首次加载慢的问题 参考文章: (1)nginx配置解决vue单页面打包文件大,首次加载慢的问题 (2)https://www.cnblogs.com/golo ...

  5. nignx部署Vue单页面刷新路由404问题解决

    nignx部署Vue单页面刷新路由404问题解决 参考文章: (1)nignx部署Vue单页面刷新路由404问题解决 (2)https://www.cnblogs.com/wuchenggong/p/ ...

  6. fullpage在vue单页面当中使用会出现的问题以及解决办法

    fullpage在vue单页面当中使用会出现的问题以及解决办法 参考文章: (1)fullpage在vue单页面当中使用会出现的问题以及解决办法 (2)https://www.cnblogs.com/ ...

  7. php vue seo,处理 Vue 单页面 SEO 的另一种思路

    (设置vue 单页面meta info信息,如果需要单页面SEO,可以和 prerender-spa-plugin形成更优的配合) 单页面应用在前端正大放光彩.三大框架 Angular.Vue.Rea ...

  8. Vue 单页面应用 把公共组件放在 app.vue 但是我希望某个页面没有这些公共组件怎么办???(比如登陆页面)

    <div  class="all"  v-if="$route.path!=='/login'" > Vue 单页面应用 把公共组件放在 app.v ...

  9. vue 单页面(SPA) history模式调用微信jssdk 跳转后偶尔 “invalid signature“错误解决方案

    vue 单页面(SPA) history模式调用微信jssdk 跳转后偶尔 "invalid signature"错误解决方案 参考文章: (1)vue 单页面(SPA) hist ...

最新文章

  1. linux nor flash 读写,9.2 NorFLASH读写实验——M25PExx
  2. SAP 序列号里主批次与库存批次不同,会有什么后果
  3. Charles的功能操作
  4. 使用C#开发ActiveX控件[Obsolete]
  5. 在安卓JNI/NDK中使用C++11
  6. js \n直接显示字符串_显示N个字符的最短时间
  7. eclipse添加源码的另外一种方法
  8. 软件设计师12-数据库(范式)
  9. GIT代码管理: git remote add
  10. C#中Font类详解
  11. IOS 中description 和 debugDescription的区别
  12. linux目录存 xml文件,将IDEA maven项目中src源代码下的xml等资源文件编译进classes文件夹...
  13. 给 Android 开发者的 Kotlin 教程(一)
  14. Android解决手机图片压缩后旋转问题
  15. UE4编辑器ToolBar扩展
  16. 多重阴影的设置、鼠标激活时、相邻选择器的简介、display
  17. Java实现 N的阶乘
  18. C++实现基于博弈树的5x5一子棋人机对战
  19. 光电对抗发现历史、内容、原理及发展趋势
  20. python手记(四):pillow(四) ImageDraw模块 图片绘制(图片上自定义绘制)

热门文章

  1. 120306 php,LAMP搭建之源码篇
  2. Mosquitto局域网访问设置
  3. 郑州大学校园网连接有线网Linux和windows还有mac系统
  4. 乔布斯女儿嘲讽iPhone 14没新意;高德打车AR实景找车功能上线;Go语言报告:错误处理仍然是个挑战|极客头条...
  5. IDEA EasyCode Oracle映射关系
  6. Pspice和MATLAB-Simulink联合仿真
  7. Origin学习分享——图形绘制
  8. 【问题解决】关于爬虫被封的处理方法(同花顺数据获取问题)
  9. Linux Tomcat下载
  10. 对n个数进行全排列并打印全排列结果