Vue中keep-alive在路由鉤子設(shè)置緩存或者不緩存如有 3 個路由 A、B、C, B 跳到 A,A 不刷新 C 跳到 A,A 刷新
我在網(wǎng)上找的代碼第一次的時候沒有效果,但是之后就正常了,不知道什么原因?qū)е碌?br>router
App.vue
<keep-alive>
<router-view v-if="$route.meta.keepAlive">
<!-- 這里是會被緩存的視圖組件,比如 Home! -->
</router-view>
</keep-alive>
<router-view v-if="!$route.meta.keepAlive">
<!-- 這里是不被緩存的視圖組件,比如 Edit! -->
</router-view>
在C中 C 到 A A刷新
beforeRouteLeave(to, from, next) {
// 設(shè)置下一個路由的 meta
to.meta.keepAlive = false; // 讓 A 不緩存,即刷新
next();
},
B到A A不刷新
beforeRouteLeave(to, from, next) {
to.meta.keepAlive = true; // 讓 A 緩存,即不刷新
next();
}
為什么第一次沒有效果 之后就正常了呢? 請求怎么解決呢?
我也有同樣的問題,解決了嗎?
(個人猜想1 因為有兩個 router-view , 第一次加載下面的不緩存,而緩存的里面卻沒有,只有加載一次緩存的頁面后,才會有)
(個人猜想2 是因為設(shè)置keep-alive的時機(jī)已經(jīng)晚了。當(dāng)導(dǎo)航已經(jīng)知道要去B頁面后,此時再設(shè)置是否緩存B已經(jīng)晚了,只會再下次生效了。)
你所說的那種方法不太好。 官方也沒有那種用法。。解決方法如下:
A-->B ,B不存, C-->B ,B存
思路基于 A --> B --> C 這種頁面關(guān)系
具體思路是: (這個思路應(yīng)該驗證了猜想2)
1、用vuex 存儲需要緩存的頁面B的名稱。
<keep-alive :include="$store.state.keepAlives">
<router-view></router-view>
</keep-alive>
2、再結(jié)合 導(dǎo)航守衛(wèi)
從A-->B的時候,設(shè)置vuex 緩存, 這樣B頁面在去其他頁面時,就被緩存了。從其他頁面到B就加載緩存數(shù)據(jù)(C就是其他頁面),
從B-->A的時候,設(shè)置vuex 不緩存(刪除B頁面名字), 這樣離開B頁面到A,B就沒有緩存下來, 你從A-->B 就不是緩存的。符合要求 (離開B的時候就設(shè)置下次進(jìn)來是否緩存。這樣避開了猜想2)
A頁面的 導(dǎo)航守衛(wèi)
beforeRouteLeave(to, from, next) {
// 設(shè)置下一個路由的
if(to.name=='B'){
this.$store.commit('setkeepAlives',['B'])
}
next();
},
B頁面的 導(dǎo)航守衛(wèi)
beforeRouteLeave(to, from, next) {
// 設(shè)置下一個路由的
if(to.name=='A'){
this.$store.commit('setkeepAlives',[])
}
next();
},
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。