欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決Vue keep-alive 調(diào)用 $destory() 頁(yè)面不再被緩存的情況

 更新時(shí)間:2020年10月30日 10:33:45   作者:風(fēng)傷影  
這篇文章主要介紹了解決Vue keep-alive 調(diào)用 $destory() 頁(yè)面不再被緩存的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

需求:

項(xiàng)目中需要開(kāi)發(fā)一個(gè)導(dǎo)航欄,類(lèi)似瀏覽器的導(dǎo)航,沒(méi)有關(guān)閉的時(shí)候頁(yè)面緩存,關(guān)掉之后,頁(yè)面隨之銷(xiāo)毀。(如圖)

項(xiàng)目是使用Vue + Vue-Router + Vuex

剛開(kāi)始使用的方法是:關(guān)閉導(dǎo)航標(biāo)簽,直接調(diào)用對(duì)應(yīng)的頁(yè)面的$destory()方法,OK,可以實(shí)現(xiàn)關(guān)閉頁(yè)面(下次再打開(kāi)該頁(yè)面,將初始化)的功能,但是遇到個(gè)問(wèn)題:

該頁(yè)面將不再被緩存,也就是說(shuō)切換導(dǎo)航tab時(shí),頁(yè)面將不斷的被初始化?。?!

查了一下文檔,找了度娘,沒(méi)發(fā)現(xiàn)解決方法,又去請(qǐng)教G哥,這才發(fā)現(xiàn)原來(lái)Vue keep-alive真的有這個(gè)問(wèn)題哎,這個(gè)是(鏈接),要么你自己去看,要么看我的解決方法,嘿嘿嘿,不瞎扯啦,上方法,其實(shí)Vue的文檔里面也寫(xiě)了的這里

keep-alive 可以傳入兩種參數(shù),貼一下官方說(shuō)明:

include 和 exclude 屬性允許組件有條件地緩存。二者都可以用逗號(hào)分隔字符串、正則表達(dá)式或一個(gè)數(shù)組來(lái)表示:

< keep-alive include=”a,b”>
< component :is=”view”>
< /keep-alive>
< !– 正則表達(dá)式 (使用 v-bind) –>
< keep-alive :include=”/a|b/”>
< component :is=”view”>
< / keep-alive>
< !– 數(shù)組 (使用 v-bind) –>
< keep-alive :include=”[‘a(chǎn)', ‘b']”>
< component :is=”view”>
< /keep-alive>`

匹配首先檢查組件自身的 name 選項(xiàng),如果 name 選項(xiàng)不可用,則匹配它的局部注冊(cè)名稱(chēng) (父組件 components 選項(xiàng)的>>鍵值)。匿名組件不能被匹配。

keep-alive 不會(huì)在函數(shù)式組件中正常工作,因?yàn)樗鼈儧](méi)有緩存實(shí)例。

差不多看明白了吧,頁(yè)面的銷(xiāo)毀不一定非得調(diào)用$destory() 去做,我理一下思路(include):

首先在vuex里面定義一個(gè)數(shù)組 includePageNames,這個(gè)數(shù)組存放的是當(dāng)前導(dǎo)航欄上顯示的頁(yè)面的名字name(在每個(gè)頁(yè)面的Vue文件中,定義name的值)

當(dāng)頁(yè)面打開(kāi)的時(shí)候,將該頁(yè)面的name加($commit)到includePageNames中

當(dāng)頁(yè)面關(guān)閉的時(shí)候,將includePageNames中該頁(yè)面對(duì)應(yīng)的name移除掉,這時(shí)候該頁(yè)面液將從緩存中被移除,這不就達(dá)到我們想要的結(jié)果了嗎

具體代碼我就不上了,就提一下我遇到的問(wèn)題:keep-alive 給它傳入includePageNames(數(shù)組),居然報(bào)錯(cuò),原因是它實(shí)際上需要一個(gè)正則表達(dá)式、或者一個(gè)逗號(hào)分隔的String,沒(méi)辦法啦,直接將includePageNames.toString()傳過(guò)去就OK啦

補(bǔ)充知識(shí):vue 頁(yè)面保留緩存和清除緩存

路由:

routes: [{
    path: '/page1',
    name: page1',
    component: page1',
    meta:{
          keepAlive:true //true是保存緩存,false是不保存
         } 
},{
path: '/page2',
    name: page2',
    component: page2',
     meta:{
          keepAlive:true
         }
 
}]

頁(yè)面js:

 /**
  * 判斷是否要清除緩存,beforeRouteLeave與methods等平級(jí)
  */
  beforeRouteLeave(to, from, next) {  //參數(shù)(馬上去的頁(yè)面,現(xiàn)在的頁(yè)面,跳轉(zhuǎn))
  if(判斷條件){
     to.meta.keepAlive = false //將要去的那個(gè)頁(yè)面的緩存清空
  }else{
    to.meta.keepAlive = true  //將要去的那個(gè)頁(yè)面的緩存保留
  }
  next();
 },

以上這篇解決Vue keep-alive 調(diào)用 $destory() 頁(yè)面不再被緩存的情況就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 基于vue監(jiān)聽(tīng)滾動(dòng)事件實(shí)現(xiàn)錨點(diǎn)鏈接平滑滾動(dòng)的方法

    基于vue監(jiān)聽(tīng)滾動(dòng)事件實(shí)現(xiàn)錨點(diǎn)鏈接平滑滾動(dòng)的方法

    本篇文章主要介紹了基于vue監(jiān)聽(tīng)滾動(dòng)事件實(shí)現(xiàn)錨點(diǎn)鏈接平滑滾動(dòng)的方法,非常具有實(shí)用價(jià)值,有興趣的可以了解一下
    2018-01-01
  • vue+elementUI下拉框回顯問(wèn)題及解決方式

    vue+elementUI下拉框回顯問(wèn)題及解決方式

    這篇文章主要介紹了vue+elementUI下拉框回顯問(wèn)題及解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 徹底揭秘keep-alive原理(小結(jié))

    徹底揭秘keep-alive原理(小結(jié))

    這篇文章主要介紹了徹底揭秘keep-alive原理(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-05-05
  • 淺談Vue?DIFF

    淺談Vue?DIFF

    本文主要介紹了淺談Vue?DIFF,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue3中effect函數(shù)到底是什么詳解

    vue3中effect函數(shù)到底是什么詳解

    Effect幾乎是Vue3.0中最重要的一個(gè)功能了,計(jì)算屬性監(jiān)聽(tīng)函數(shù)都是基于effect實(shí)現(xiàn)的,下面這篇文章主要給大家介紹了關(guān)于vue3中effect函數(shù)到底是什么的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • vue如何定義全局變量和全局方法實(shí)例代碼

    vue如何定義全局變量和全局方法實(shí)例代碼

    在項(xiàng)目中經(jīng)常會(huì)復(fù)用一些變量和函數(shù),比如用戶(hù)的登錄token,用戶(hù)信息等,這時(shí)將它們?cè)O(shè)為全局的就顯得很重要了,下面這篇文章主要給大家介紹了關(guān)于vue如何定義全局變量和全局方法的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • 詳解使用VueJS開(kāi)發(fā)項(xiàng)目中的兼容問(wèn)題

    詳解使用VueJS開(kāi)發(fā)項(xiàng)目中的兼容問(wèn)題

    這篇文章主要介紹了詳解使用VueJS開(kāi)發(fā)項(xiàng)目中的兼容問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • vue 添加vux的代碼講解

    vue 添加vux的代碼講解

    通過(guò)命令npm install vux --save添加vux,在相關(guān)配置文件中配置信息,具體代碼添加方法,大家參考下本文
    2017-11-11
  • Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車(chē)頁(yè)面

    Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車(chē)頁(yè)面

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡(jiǎn)易購(gòu)物車(chē)頁(yè)面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • vue中如何利用js函數(shù)截取時(shí)間的年月日時(shí)分秒

    vue中如何利用js函數(shù)截取時(shí)間的年月日時(shí)分秒

    時(shí)分秒都是跟月份一樣,從0開(kāi)始數(shù)的,不用+1,因?yàn)樵率?-12月,而時(shí)分秒是0-23和0-59,下面這篇文章主要給大家介紹了關(guān)于vue中如何利用js函數(shù)截取時(shí)間的年月日時(shí)分秒的相關(guān)資料,需要的朋友可以參考下
    2022-11-11

最新評(píng)論