vue 詳情跳轉至列表頁實現(xiàn)列表頁緩存
甲爸爸提了一個需求,希望公眾號內(nèi)的商城能夠像app一樣,從商品詳情頁跳轉至列表頁及其他列表頁時,可以實現(xiàn)列表頁緩存(數(shù)據(jù)不刷新、位置固定到之前點的商品的位置)
本來想著scrollBehavior應該可以滿足,但是實際操作中發(fā)現(xiàn):如果列表帶著分頁,位置是不會定位到點擊的位置的

在網(wǎng)上轉了一圈,終于找到適合自己的方法——beforeRouteLeave
注:beforeRouteLeave只對一級頁面起作用,不適用于children中的其他二級或其他級別的頁面
以上是準備工作,接下來 可以步入正題了:
找到入口掛載頁面:App.vue 在router-view外部包裹一個keep-alive的標簽
因為不是所有頁面都需要緩存,所以把需要緩存的頁面中加入name值,并將name值加入keep-alive中
<keep-alive v-if="isRouterAlive" include="starShop" > <router-view></router-view> </keep-alive>
當然,僅僅是這些,是不能實現(xiàn)緩存的,
剛開始我是學著網(wǎng)上的方法,這樣寫的,當從列表點入詳情頁時,就將 列表頁的keepalive值,賦為true (實現(xiàn)緩存)
beforeRouteLeave(to, from, next) {
if(from.path == '/sale/newGoods/index' && to.path == '/goods/detail') {
from.meta.keepAlive = true;
this.loading = true;
next();
return
} else {
from.meta.keepAlive = false;
window.location.reload();
this.$destroy();
next();
return
}
},
但是后期甲爸爸發(fā)現(xiàn)一個bug: 當我從列表一點擊進入詳情之后,如果直接從詳情頁,點擊進入別的店鋪列表頁,即列表二,最新的列表頁內(nèi)展示的商品列表是之前的數(shù)據(jù),并沒有變?yōu)樽钚碌牡赇伭斜韮?nèi)容 , 即列表二頁面展示的還是列表一的商品
玩大了,這個問題比較著急啊,萬一把顧客繞暈了,人家不買東西了,那我罪過不就大了咩

晚上趁著月黑風高、夜深人靜的時候,我苦思冥想,終于把這個社會毒瘤挖掉了
我絕不是屈居于甲爸爸的淫威之下,只是因為我對技術的執(zhí)著,過度追求完美的我,忍受不聊我的東西出現(xiàn)這樣大的漏洞
要看解決辦法的直接來這 ↓↓↓↓↓↓
首先摒棄上面的列表頁面的方法
第一步:找到商品詳情頁,最為主角之一,我在這里用到了beforeRouteEnter、beforeRouteLeave
beforeRouteEnter (to, from, next) {
next(vm =>{
vm.formUrl = from.path;
console.log(vm.formUrl)
});
},
beforeRouteLeave(to, from, next) {
to.meta.keepAlive = false;
if(to.path == this.formUrl){
to.meta.keepAlive = true;
next();
return
}else{
to.meta.KeepAlive = false;
window.localStorage.removeItem('isRefresh')
this.$destroy();
next();
return
}
},
beforeRouteEnter:進入路由之前執(zhí)行的函數(shù)(拿到列表一的路由)
beforeRouteLeave:離開路由之前執(zhí)行的函數(shù)(拿到列表二的路由)
通過這兩個鉤子,可以成功的拿到事件的另外兩位主角路由(列表一、列表二)
在詳情頁中,當離開該頁之前,在beforeRouteLeave內(nèi)進行列表一、列表二的路由比較
若兩路由相同,則跳轉目的頁面(to.meta.keepAlive)值為true,列表頁面進行緩存(比如從詳情頁返回的時候)
若兩路由不同,則跳轉目的頁面發(fā)生了變化(比如從鞋帽列表——>鞋子商品——>鞋子列表),則鞋子列表頁面不需要緩存,需要刷新獲取最新的鞋子列表數(shù)據(jù)
第二步:處理事件的第二主角——列表頁面
這里我僅用到了beforeRouteEnter
這個鉤子中,我們可以拿到當前頁面的keepAlive值
這個值是在詳情頁中就已經(jīng)給定的
如果是true,表示緩存,否則為不緩存(刷新)
防止頁面一直刷新,變成死亡函數(shù),我們要在data中聲明一個變量isRefresh
isRefresh: window.localStorage.getItem('isRefresh') || true
beforeRouteEnter (to, from, next) {
next(vm =>{
if(to.meta.keepAlive != true && to.meta.keepAlive != null){
vm.goods=[];
window.localStorage.setItem('isRefresh',true)
if(JSON.stringify(window.localStorage.getItem('isRefresh')) != false){
window.localStorage.setItem('isRefresh',false)
location.reload();
}
}
});
return
},
如果當前頁to.meta.keepAlive值不為true,且值存在,則需刷新頁面
防止頁面一直刷新,
window.localStorage.setItem('isRefresh',true)
設置緩存變量isRefresh,值為true(表示需要刷新)
當to.meta.keepAlive值不為true且isRefresh值為true,頁面刷新,且isRefresh賦值為false,即關閉刷新
vm.goods=[];是當頁面跳去新的列表頁刷新之前,會出現(xiàn)短暫的列表展示,為了避免不必要的誤導,在檢測到是跳轉到新的列表頁時,我將列表頁的goods列表情況,視覺感受會好一些
因項目不同而異,不需要可以去掉
多張頁面之間跳轉,判斷是否需要緩存或刷新獲取新數(shù)據(jù),就是這樣了
或許因為業(yè)務需求不同,技術處理方式可能會不同,希望能幫助到各位,或者給各位一些啟發(fā),也希望大家多多支持腳本之家。
相關文章
使用vuex的時候,出現(xiàn)this.$store為undefined問題
這篇文章主要介紹了使用vuex的時候,出現(xiàn)this.$store為undefined問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
利用Vue3和element-plus實現(xiàn)圖片上傳組件
element-plus提供了uploader組件,但是不好定制化。所以本文將利用Vue3和element-plus實現(xiàn)一個圖片上傳的組件,感興趣的可以了解一下2022-03-03
vue?中使用?this?更新數(shù)據(jù)的一次問題記錄
這篇文章主要介紹了vue?中使用?this?更新數(shù)據(jù)的一次大坑?,我在 vue 實例中聲明了一個數(shù)組屬性如?books: [],在異步請求的回調函數(shù)中使用?this.books = res.data.data;?進行數(shù)據(jù)更新,感興趣的朋友跟隨小編一起看看吧2022-11-11
關于vue-socket.io使用及版本原因消息無法監(jiān)聽bug
這篇文章主要介紹了關于vue-socket.io使用及版本原因消息無法監(jiān)聽bug,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10

