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

A页:

B页:

html

解决方法:

利用keep-alive 缓存须要缓存的页面

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

2.在router/index.js中添加路由元信息,设置须要缓存的页面

keepAlive:设置须要缓存的页面

isBack:经过beforeRouteEnter这个钩子函数中的from参数判断是从哪一个页面过来的,这个参数执行时,组件实例还没建立,不能在data中定义变量。因此咱们能够在路由中定义一个变量isBack,用来判断。webpack

{

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中比较重要的两个钩子函数,建议详细了解下。web

在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.html

if (from.path === '/detail'){

//判断是从哪一个路由过来的,

//若是是B页面即detail页面过来的,代表当前页面不须要刷新获取新数据,直接用以前缓存的数据便可

to.meta.isBack = true;

}else{

to.meta.isBack = false;

}

next();

},

data中定义变量isFirstEnter用来判断是否第一次进入,或是否刷新了页面,默认false

data() {

return {

isFirstEnter:false,

};

},

created中把isFirstEnter变为true,说明是第一次进入或刷新了页面

created() {

this.isFirstEnter=true;

// 只有第一次进入或者刷新页面后才会执行此钩子函数

// 使用keep-alive后(2+次)进入不会再执行此钩子函数

this.$nextTick(() => {

this.getLists();

});

},

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=false

this.isFirstEnter=false;

}

},

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

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

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

  2. vue单页面 回退页面 keeplive 缓存问题

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

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

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

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

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

  5. 使用 Vue.js 和 Flask 实现全栈单页面应用

    原文链接: codeburst.io 在本教程中,我将向大家展示如何使用前端的 Vue.js 单页面应用和后端的 Flask 进行交互. 如果你只是想使用 Vue.js 库和 Flask 模板基本上是 ...

  6. 根据vue的脚手架 简单的搭建一个单页面

    根据vue的脚手架 简单的搭建一个单页面 1.首先需要安装npm node.js 自带,所以去安装node.js 就可以了. node中文网址 这里是网址 或者自行百度,网上很好找.另外还需要手动安装 ...

  7. vue单页面跳页没有数据了_详解刷新页面vuex数据不消失和不跳转页面的解决

    先说点什么 vuex和路由拦截这一块捣鼓的有一段时间了,总算是爬出来了,特地来分享一下,首先声明没有什么基础介绍,用的是登录状态存储sessionStorage的方法!!! 进入正题 刷新 刷新相当与 ...

  8. activiti表单设计器_基于Vue,ElementUI开发的一款表单设计器

    介绍 基于Vue,ElementUI开发的一款表单设计器,提高表单开发效率的利器,让开发者从枯燥的表单代码编写中解放出来 工具地址: http://tools.xiaoyaoji.cn/form Gi ...

  9. vue+element 实现试卷答题功能,单选题 ,多选题,判断题,简答题(2.0版本,2021.3.25更新)

    vue+element 实现 试卷答题功能,单选题 ,多选题,判断题,简答题(2.0版本,2021.3.25更新) 文章目录 vue+element 实现 试卷答题功能,单选题 ,多选题,判断题,简答 ...

  10. 基于Vue,ElementUI开发的一款表单设计器

    介绍 基于Vue,ElementUI开发的一款表单设计器,提高表单开发效率的利器,让开发者从枯燥的表单代码编写中解放出来 工具地址:http://form.making.link GitHub地址:h ...

最新文章

  1. python 正则表达式贪婪模式与非贪婪模式
  2. 达梦数据库中服务器日志的开关
  3. DCIC巡游车与网约车运营特征对比分析-数据读取
  4. Bootstrap HTML 编码规范之JavaScript生成的标签
  5. vue动态设置文字布局方式_十大惊人的文字动画特效
  6. 线程同步与互斥........
  7. 数据是否服从正态分布
  8. 【Python】Python IDLE 设置清屏功能(清屏快捷键Ctrl+w,亲测通用)
  9. CAN总线和RS485的比较:
  10. java中使用unzip_unzip命令_Linux unzip命令用法示例详解
  11. CRM系统实现企业管理高效协同
  12. 解决浏览器主页被2345篡改
  13. 内核同步机制——蜗窝科技
  14. Web 攻防之业务安全:越权访问漏洞 测试.
  15. 再见Dubbo,不学会新的Java开发框架。你以为阿里P7能这么好拿?
  16. IPAD成功完美越狱
  17. 电平是什么?单片机的I/0口输入和输出,1和0是什么?什么是TTL电平?TTL电平分析?TTL、CMOS、RS232、RS485电平差异?usb转ttl?CH340模块驱动安装?电平之间的转换?
  18. VR,正在上演一出“风月宝鉴”
  19. http://www.cnblogs.com/alcc/p/Allc.html
  20. led灯条维修_LED灯坏了别着急,三种故障的解决方案在这里

热门文章

  1. 阿里云矢量图html页面引入,iconfont 阿里巴巴矢量图标库使用说明
  2. 如何简单使用阿里巴巴矢量图标库!?
  3. Win10问题篇:使用微PE装机。(完整版教程)
  4. R语言和Rstudio的介绍和安装
  5. 超强扒站神器:SiteSucker Pro for Mac(4.1.3多语言)
  6. 勒让德多项式学习笔记
  7. 《软件体系结构》第二章 软件体系结构建模
  8. 原生js追加html代码,原生js动态添加元素
  9. 兴业数金牛客java笔试题
  10. 达梦数据库管理工具介绍