首页 >> js开发 >> js解决vue单页面 回退页面 keeplive 缓存问题js大全
js解决vue单页面 回退页面 keeplive 缓存问题js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
场景:项目中遇到 vue 点击回退 从A页跳到B页,缓存A页,当B页状态修改再次返回A时,A页查询条件缓存不刷新,列表刷新A页:A页:B页:B页:解决方法:解决方法:解决方法:利用keep-alive 缓存需要缓存的页面1.在app.vue中改写router-view
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,//用于判断上一个页面是哪个
}
},
{
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
beforeRouteEnter --> created --> mounted --> destroyed使用keep-alive
beforeRouteEnter --> created --> mounted --> activated --> deactivated
beforeRouteEnter --> created --> mounted --> activated --> deactivated再次进入缓存的页面,只会触发beforeRouteEnter -->activated --> deactivated 。created和mounted不会再执行。我们可以利用不同的钩子函数,做不同的事。务必理解上述钩子函数的执行时机和执行顺序,本教程的核心就依赖于此钩子函数activated和deactivated是使用keep-alive后,vue中比较重要的两个钩子函数,建议详细了解下。在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();
},
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,
};
},
data() {
return {
isFirstEnter:false,
};
},created中把isFirstEnter变为true,说明是第一次进入或刷新了页面
created() {
this.isFirstEnter=true;
// 只有第一次进入或者刷新页面后才会执行此钩子函数
// 使用keep-alive后(2+次)进入不会再执行此钩子函数
this.$nextTick(() => {
this.getLists();
});
},
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;
}
},
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单页面 回退页面 keeplive 缓存问题就是小编分享给大家的全部内容了,希望能给大家一个参考。
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,//用于判断上一个页面是哪个
}
},
{
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
beforeRouteEnter --> created --> mounted --> destroyed使用keep-alive
beforeRouteEnter --> created --> mounted --> activated --> deactivated
beforeRouteEnter --> created --> mounted --> activated --> deactivated再次进入缓存的页面,只会触发beforeRouteEnter -->activated --> deactivated 。created和mounted不会再执行。我们可以利用不同的钩子函数,做不同的事。务必理解上述钩子函数的执行时机和执行顺序,本教程的核心就依赖于此钩子函数activated和deactivated是使用keep-alive后,vue中比较重要的两个钩子函数,建议详细了解下。在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();
},
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,
};
},
data() {
return {
isFirstEnter:false,
};
},created中把isFirstEnter变为true,说明是第一次进入或刷新了页面
created() {
this.isFirstEnter=true;
// 只有第一次进入或者刷新页面后才会执行此钩子函数
// 使用keep-alive后(2+次)进入不会再执行此钩子函数
this.$nextTick(() => {
this.getLists();
});
},
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;
}
},
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单页面 回退页面 keeplive 缓存问题就是小编分享给大家的全部内容了,希望能给大家一个参考。