vue移動端項(xiàng)目緩存問題實(shí)踐記錄
最近在做一個(gè)vue移動端項(xiàng)目,被緩存問題搞得頭都大了,積累了一些經(jīng)驗(yàn),特此記錄總結(jié)下,權(quán)當(dāng)是最近項(xiàng)目問題的一個(gè)回顧吧!
先描述下問題場景:A頁面->B頁面->C頁面。假設(shè)A頁面是列表頁面,B頁面是列表詳情頁面,C頁面是操作改變B頁面的一些東西,進(jìn)行提交類似的操作。A頁面進(jìn)入B頁面,應(yīng)該根據(jù)不同的列表item顯示不一樣的詳情,從B進(jìn)入C,也應(yīng)該根據(jù)item的標(biāo)識比如ID展示不一樣的內(nèi)容,在C頁面操作后,返回B頁面,B頁面數(shù)據(jù)發(fā)生變化。這個(gè)時(shí)候會有兩種情況:
- C頁面操作數(shù)據(jù)后返回B頁面,B頁面對應(yīng)數(shù)據(jù)應(yīng)該發(fā)生變化。
- C頁面直接點(diǎn)擊左上角箭頭返回,B頁面對應(yīng)數(shù)據(jù)不應(yīng)該發(fā)生變化。繼續(xù)返回A列表頁面,換一條數(shù)據(jù),繼續(xù)進(jìn)入B頁面,B頁面展示不同內(nèi)容,進(jìn)入C頁面,C頁面刷新展示不同內(nèi)容
另一種情況發(fā)生在寫郵件的頁面中,添加收件人,選人之后,繼續(xù)添加,之前添加的聯(lián)系人應(yīng)該存在。但是從寫郵件頁面返回郵件列表再次進(jìn)入寫郵件頁面,之前添加過的聯(lián)系人數(shù)據(jù)就不應(yīng)該存在了,這里就涉及到如何處理緩存,何時(shí)使用緩存,何時(shí)清除緩存的問題了。
目前項(xiàng)目整體結(jié)構(gòu)如下:
<template> <div id="app"> <keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view> </div> </template>
雖然官方提供了include,exclude,可以讓我們決定哪些組件使用緩存,哪些不使用緩存,但是并沒有解決我們想動態(tài)使用緩存的目的,目前我的項(xiàng)目使用了如下兩種方式處理緩存:
方式一 ,使用是否使用緩存標(biāo)識
在路由文件router.js里給每個(gè)路由添加meta信息,標(biāo)識是否使用緩存。
meta: {
isUseCache: false,//不使用緩存
keepAlive: true
}
使用方式:
A->B,B不能緩存;B->A,A緩存。
(1)A頁面:
beforeRouteLeave(to, from, next) {
// 設(shè)置下一個(gè)路由的 meta
if(to.path=='/B'){
to.meta.isUseCache = false;
}
next();
},
activated(){
if(!this.$route.meta.isUseCache){
this.getData();
}
}
(2) B頁面
beforeRouteLeave(to, from, next) {
// 設(shè)置下一個(gè)路由的 meta
if(to.path=='/A'){
to.meta.isUseCache = true;
}
next();
},
activated(){
if(!this.$route.meta.isUseCache){
this.getData();
}
}
方式二,強(qiáng)制清除緩存。
這種方式是從網(wǎng)上找的一種方式,使用了vue內(nèi)部組件之后,不在支持動態(tài)銷毀組件,緩存一直存在,只能從源頭上下手,清掉緩存。
export const removeCatch = {
beforeRouteLeave:function(to, from, next){
if (from && from.meta.rank && to.meta.rank && from.meta.rank>to.meta.rank)
{//此處判斷是如果返回上一層,你可以根據(jù)自己的業(yè)務(wù)更改此處的判斷邏輯,酌情決定是否摧毀本層緩存。
if (this.$vnode && this.$vnode.data.keepAlive)
{
if (this.$vnode.parent && this.$vnode.parent.componentInstance && this.$vnode.parent.componentInstance.cache)
{
if (this.$vnode.componentOptions)
{
var key = this.$vnode.key == null
? this.$vnode.componentOptions.Ctor.cid + (this.$vnode.componentOptions.tag ? `::${this.$vnode.componentOptions.tag}` : '')
: this.$vnode.key;
var cache = this.$vnode.parent.componentInstance.cache;
var keys = this.$vnode.parent.componentInstance.keys;
if (cache[key])
{
if (keys.length) {
var index = keys.indexOf(key);
if (index > -1) {
keys.splice(index, 1);
}
}
delete cache[key];
}
}
}
}
this.$destroy();
}
next();
}
};
在需要清掉緩存的頁面混合引入該js即可。
總結(jié)
以上所述是小編給大家介紹的vue移動端項(xiàng)目緩存問題實(shí)踐記錄,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
基于Vue實(shí)現(xiàn)的多條件篩選功能的詳解(類似京東和淘寶功能)
這篇文章主要介紹了Vue多條件篩選功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
vue(element ui)el-table樹形表格展示以及數(shù)據(jù)對齊方式
這篇文章主要介紹了vue(element ui)el-table樹形表格展示以及數(shù)據(jù)對齊方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
vue.js 實(shí)現(xiàn)輸入框動態(tài)添加功能
這篇文章主要介紹了vue.js 實(shí)現(xiàn)輸入框動態(tài)添加功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06
vue實(shí)現(xiàn)button按鈕的重復(fù)點(diǎn)擊指令方式
這篇文章主要介紹了vue實(shí)現(xiàn)button按鈕的重復(fù)點(diǎn)擊指令方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
vue構(gòu)建單頁面應(yīng)用實(shí)戰(zhàn)
本篇文章主要介紹了vue構(gòu)建單頁面應(yīng)用實(shí)戰(zhàn),使用 SPA,沒有頁面切換,就沒有白屏阻塞,可以大大提高 H5 的性能,達(dá)到接近原生的流暢體驗(yàn)。2017-04-04

