1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > vue单页面html缓存问题 vue单页面 回退页面 keeplive 缓存问题

vue单页面html缓存问题 vue单页面 回退页面 keeplive 缓存问题

时间:2020-08-22 11:22:44

相关推荐

vue单页面html缓存问题 vue单页面 回退页面 keeplive 缓存问题

场景:项目中遇到 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除外)

// 参考 /zh-cn/advanced/navigation-guards.html

// 因此,利用路由元信息中的meta字段设置变量,方便在各个位置获取。这就是为何在meta中定义isBack

// 参考 /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;

}

},

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。