vue路由中前進(jìn)后退的一些事兒
前言
最近蒸煮在做一個獨立項目的時候遇到了一個小坑,特此做個爬坑紀(jì)念。
基本情景是頁面之間通過vue路由跳轉(zhuǎn),從頁面A跳轉(zhuǎn)到頁面B(在頁面B進(jìn)行對應(yīng)操作后),再從頁面B跳轉(zhuǎn)到頁面C。之后再從頁面C返回到頁面B,頁面B保留之前狀態(tài),返回頁面A,頁面B狀態(tài)不保留。(。・∀・)ノ゙嗨~感覺說的好亂。
總之就是,前進(jìn)刷新,后退不刷新(刷新是指是否重新渲染)
相信很多小伙伴都會想到用keep-alive開啟緩存頁面來實現(xiàn),鵝,蒸煮也沒例外,下面就是蒸煮的爬坑過程。
vue路由開啟keep-alive緩存頁面
keep-alive是vue官方提供的一種緩存組件實例的方法。
第一步,先改寫<router-view>的展示方式
<keep-alive> //這是會被緩存的頁面 <router-view v-if="$route.meta.keepAlive"> </router-view></keep-alive> <router-view v-if = "!$route.meta.keepAlive"> //這里是不被緩存的組件 </router-view>
第二步,在路由配置文件里,配置組件是否被緩存
routes:[
{ path: '/',
name: 'Index',
component: Index,
meta:{
title:"博物館",
keepAlive:false//不緩存
}
},
{
path:'/searchMain',
name:'SearchMain',
component:SearchMain,
meta:{
title:"搜索",
keepAlive:true,//緩存
}
},
{
path:'/collectionDetails',
name:'CollectionDetails',
component:CollectionDetails,
meta:{
title:"藏品詳情",
keepAlive:false,//不緩存
}
}]
這樣的話無論什么時候,緩存的組件一直會被緩存
第三步,根據(jù)路由鉤子來改變緩存組件的狀態(tài)
beforeRouteLeave(to, from, next) {
if(to.path="首頁"){
from.meta.keepAlive =false;
}else if(to.path="詳情頁"){
from.meta.keepAlive = true;
} // 跳轉(zhuǎn)到 首頁時,不緩存,跳轉(zhuǎn)到詳情頁時緩存(就是不刷新)
next();
}
這種行嗎?行嗎?行嗎?不行!!因為第一次的時候確實會成功,可是退出去以后就gg了,
因為keepAlive已經(jīng)變成了false,第二次就不會緩存。那么第一個頁面加下面代碼,讓他進(jìn)入的時候
beforeRouteLeave(to, from, next) {
if(to.path=="/searchMain"){
to.meta.keepAlive =true;
}
next(true);
return;
},
實踐證明,搜索界面的數(shù)據(jù)一直是第一次緩存過的數(shù)據(jù)。
二,為了解決這個問題,蒸煮想起了keep-alive組件相關(guān)的兩個鉤子函數(shù)。
activated:緩存的組件再次進(jìn)入時觸發(fā);
deactivated:緩存的組件離開時會觸發(fā);
第一次進(jìn)入keep-alive組件時,其生命周期執(zhí)行順序:
beforeRouteEnter ->created ->mounted ...->activated ->deactivated
非首次進(jìn)入時,其生命周期執(zhí)行順序
beforeRouteEnter ->activated ->deactivated
第二次進(jìn)入的時候vue組件的生命周期函數(shù)都沒有執(zhí)行,說明緩存組件也無法銷毀。更無法更新。
解決方法
activated() {
if(!this.$route.meta.isBack) {
// 如果isBack是false,表明需要獲取新數(shù)據(jù),否則就不再請求,直接使用緩存的數(shù)據(jù) this.getData(); // ajax獲取數(shù)據(jù)方法
}
// 恢復(fù)成默認(rèn)的false,避免isBack一直是true,導(dǎo)致下次無法獲取數(shù)據(jù)
this.$route.meta.isBack = false
},
但素,重新?lián)Q取數(shù)據(jù),之前保存在data里的數(shù)據(jù)并沒有變,感覺還是不太徹底!
終極解決方案
最后終于到答案的最后一步啦那
就是動態(tài)給要緩存的路由組件添加key值啦~
<keep-alive> <router-view v-if="$route.meta.keepAlive" :key='key'></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive" :key='key'></router-view>
在vuex中有條件改變key的值
beforeRouteLeave(to,from,next){
if(to.path=="/"){
this.$store.commit("UPDATE_KEY",this.$route.name!==undefined?this.$route.name+
+new Date():this.$route+ +new Date());
}
}
這樣的話就會有一個很重要的問題,這些緩存過的組件,都是在內(nèi)存中的,如果一直操作,內(nèi)存堆積越來越大,導(dǎo)致系統(tǒng)卡頓。所以離開時就銷毀吧
手動觸發(fā)銷毀
beforeRouteLeave(to,from,next){
if(to.path=="/"){
this.$store.commit("UPDATE_KEY",this.$route.name!==undefined?this.$route.name+ +new Date():this.$route+ +new Date());
this.$destroy();//銷毀吧
}
結(jié)語:寫完了,希望能夠供大家參考哦!
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
詳解給Vue2路由導(dǎo)航鉤子和axios攔截器做個封裝
本篇文章主要介紹了詳解給Vue2路由導(dǎo)航鉤子和axios攔截器做個封裝,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04
vue按需加載組件webpack require.ensure的方法
本篇文章主要介紹了vue按需加載組件webpack require.ensure的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12

