vue路由跳转回退后页面不刷新处理
·利用keep-alive 缓存需要缓存的页面
具体实现流程
1.在app.vue中改写router-view
<keep-alive>
<router-view v-if="$route.meta.keepAlive">
<!-- 这里是会被缓存的视图组件,比如page,page1,page2 -->
</router-view>
</keep-alive>
2.在router/index.js中添加路由元信息,设置需要缓存的页面
routes: [{
path: '/',
name: 'index',
component: index,
meta: {
keepAlive: false, //此组件不需要被缓存
}
},
{
path: '/page1',
name: 'page1',
component: page1,
meta: {
keepAlive: true, //此组件需要被缓存
}
}
]
钩子函数的执行顺序
- 不使用keep-alive
beforeRouteEnter --> created --> mounted --> destroyed - 使用keep-alive
beforeRouteEnter --> created --> mounted --> activated --> deactivated
再次进入缓存的页面,只会触发beforeRouteEnter -->activated --> deactivated 。
created和mounted不会再执行。
3. 需缓存的页面的写法
- data中初始化,存放从后台获取的数据
data() {
return {
Arr: [] // 加载页面后执行获取数据的方法,插入到此
};
}
- methods中创建一个方法,获取数据
methods: {
getData() {
// getData方法,要保存的数据
this.Arr = this.scrmMgroup;
}
}
-
修改router/index.js中的配置
每次进入页面,我们都需要知晓是从哪个页面进来的,用以判断是否需要获取数据。 在router/index.js的meta中添加isBack变量,默认false
{
path: '/page1',
name: 'page1',
component: page1,
meta: {
keepAlive: true, //此组件需要被缓存
isBack:false, //用于判断上一个页面是哪个
}
},
- beforeRouteEnter中判断是从哪个页面过来的
beforeRouteEnter(to, from, next) {
if(from.name=='posters'){
to.meta.isBack=true;
//判断是从哪个路由过来的,
}
next();
},
-
activated中执行getData这个获取数据的方法
因为这个页面需要缓存。只有第一次进入时才会执行created和mounted方法,再次进入就不执行了。而activated每次进入都执行,所以在这个钩子函数中获取数据。
activated() {
if(!this.$route.meta.isBack){
// 如果isBack是false,表明需要获取新数据,否则就不再请求,直接使用缓存的数据
this.getData();
}
// 恢复成默认的false,避免isBack一直是true,导致下次无法获取数据
this.$route.meta.isBack=false
},
使用keep-alive后,只有第一次进入后会触发created钩子函数,再次进入就不再执行了。当用户刷新了页面,这个钩子函数就会又执行所以可以在data中定义变量isFirstEnter用来判断是否第一次进入,或是否刷新了页面,默认false。created中把isFirstEnter变为true,说明是第一次进入或刷新了页面。activated中增加判断条件
activated() {
if(!this.$route.meta.isBack || this.isFirstEnter){
// 如果isBack是false,表明需要获取新数据,否则就不再请求,直接使用缓存的数据
// 如果isFirstEnter是true,表明是第一次进入此页面或用户刷新了页面,需获取新数据
this.Arr=[]
// 把数据清空,可以稍微避免让用户看到之前缓存的数据
this.getData();
}
// 恢复成默认的false,避免isBack一直是true,导致下次无法获取数据
this.$route.meta.isBack=false
// 恢复成默认的false,避免isBack一直是true,导致每次都获取新数据
this.isFirstEnter=false;
},
参考了https://blog.youkuaiyun.com/qq_40963664/article/details/80062130