老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

vue移動端項目緩存問題的示例分析-創新互聯

這篇文章給大家分享的是有關vue移動端項目緩存問題的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

在洞頭等地區,都構建了全面的區域性戰略布局,加強發展的系統性、市場前瞻性、產品創新能力,以專注、極致的服務理念,為客戶提供網站設計、成都做網站 網站設計制作按需求定制設計,公司網站建設,企業網站建設,成都品牌網站建設,營銷型網站,外貿網站制作,洞頭網站建設費用合理。

先描述下問題場景:A頁面->B頁面->C頁面。假設A頁面是列表頁面,B頁面是列表詳情頁面,C頁面是操作改變B頁面的一些東西,進行提交類似的操作。A頁面進入B頁面,應該根據不同的列表item顯示不一樣的詳情,從B進入C,也應該根據item的標識比如ID展示不一樣的內容,在C頁面操作后,返回B頁面,B頁面數據發生變化。這個時候會有兩種情況:

  • C頁面操作數據后返回B頁面,B頁面對應數據應該發生變化。

  • C頁面直接點擊左上角箭頭返回,B頁面對應數據不應該發生變化。繼續返回A列表頁面,換一條數據,繼續進入B頁面,B頁面展示不同內容,進入C頁面,C頁面刷新展示不同內容

另一種情況發生在寫郵件的頁面中,添加收件人,選人之后,繼續添加,之前添加的聯系人應該存在。但是從寫郵件頁面返回郵件列表再次進入寫郵件頁面,之前添加過的聯系人數據就不應該存在了,這里就涉及到如何處理緩存,何時使用緩存,何時清除緩存的問題了。

目前項目整體結構如下:

雖然官方提供了include,exclude,可以讓我們決定哪些組件使用緩存,哪些不使用緩存,但是并沒有解決我們想動態使用緩存的目的,目前我的項目使用了如下兩種方式處理緩存:

方式一 ,使用是否使用緩存標識

在路由文件router.js里給每個路由添加meta信息,標識是否使用緩存。

meta: {
  isUseCache: false,//不使用緩存
  keepAlive: true
}

使用方式:

A->B,B不能緩存;B->A,A緩存。

(1)A頁面:

beforeRouteLeave(to, from, next) {
 // 設置下一個路由的 meta
 if(to.path=='/B'){
  to.meta.isUseCache = false;
 }
 next();
},
activated(){
  if(!this.$route.meta.isUseCache){
    this.getData();
  }
}

(2) B頁面

beforeRouteLeave(to, from, next) {
 // 設置下一個路由的 meta
 if(to.path=='/A'){
  to.meta.isUseCache = true;
 }
 next();
},
activated(){
  if(!this.$route.meta.isUseCache){
    this.getData();
  }
}

方式二,強制清除緩存。

這種方式是從網上找的一種方式,使用了vue內部組件之后,不在支持動態銷毀組件,緩存一直存在,只能從源頭上下手,清掉緩存。

export const removeCatch = {
 beforeRouteLeave:function(to, from, next){
  if (from && from.meta.rank && to.meta.rank && from.meta.rank>to.meta.rank)
   {//此處判斷是如果返回上一層,你可以根據自己的業務更改此處的判斷邏輯,酌情決定是否摧毀本層緩存。
     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即可。

感謝各位的閱讀!關于“vue移動端項目緩存問題的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


本文名稱:vue移動端項目緩存問題的示例分析-創新互聯
標題網址:http://www.xueling.net.cn/article/dhdsjd.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 亚洲自偷观看高清久久 | 殴美成人在线视频 | 天堂网在线最新版www | 五月婷婷一区二区三区 | 亚洲欧洲日产国码无码网站 | 韩国av在线播放 | 亚洲成人网一区 | 日韩人成 | 九色在线78m | 西西人体444WWW大胆无码视频 | 亚洲国产精品ⅴa在线观看 免费日韩网站 | 综合色网站 | 男人操女人视频网站 | av成人资源| 在线观看亚洲十八禁网站 | 国产不卡av在线播放 | av色蜜桃一区二区三区 | 扒开粉嫩的小缝喷白浆h | 日本无遮挡在线观看 | 猫咪成人在线观看 | 麻豆精品久久 | 亚洲综合欧美日韩狠狠色 | 青青草护士中出内射 | 久久久久久伊人高潮影院 | 大地资源中文在线观看免费 | 久久大香伊蕉在人线免费 | 亚洲精品乱码久久久v开放时间 | 四虎永久在线精品免费AV | 好紧好湿好黄的视频 | 在线播放国产视频 | 曰韩精品一区二区 | 91校长国产在线观看 | 99久久精品国产免费看 | 国产99国产精偷国产黄在线欧洲 | 无码欧美多人性站交大战 | 美国毛片久久 | 国产亚洲精品久久久久久老妇 | 久久国产精品亚洲 | 亚洲国产福利成人一区二区 | 亚洲第一极品精品无码 | 亚洲VA中文字幕无码毛片 |