第三十八節(jié):Vue路由:keep-alive緩存路由組件

1. 為什么需要緩存組件:

理解:

  1. 默認(rèn)情況下,在切換路由時(shí),路由對(duì)應(yīng)的組件會(huì)被重新創(chuàng)建或銷毀,每次切換的路由都是新創(chuàng)
  2. 如果可以緩存路由組件,將可以提高用戶體
    • 例如用戶在登錄時(shí),輸入用戶名,切換到了其他路由,回來時(shí),原來輸入內(nèi)容還在,會(huì)怎樣


2. keep-alive緩存組件

keep-alive 是Vue內(nèi)置的組件,可以是被包含的組件被緩存,保留組件的狀態(tài),避免重新渲染

router-view 組件,如果被包裹在keep-alive里面,所以路徑匹配的組件都會(huì)被緩存

編程方式:

<keep-alive>
    <router-view></router-view>
</keep-alive>

這樣在每次切換組件時(shí),組件不會(huì)被銷毀, 組件中的狀態(tài)得以報(bào)錯(cuò)


3. 鉤子函數(shù)

說明

  1. 在最初學(xué)習(xí)組件的生命周期時(shí),學(xué)習(xí)過8個(gè)鉤子函數(shù)
  2. 如果使用keep-alive組件將會(huì)多出兩個(gè)鉤子函數(shù)分別為activateddeactivated
  3. activated 被激活, 表示被緩存的組件激活使用, 當(dāng)前處于活躍狀態(tài)
  4. deactivated 被活化,表示當(dāng)前組件雖然被緩存,但是不是處于活躍狀態(tài)

示例:

<script>
    export default {
        name:"Home",
        activated(){
            console.log("actived");

        },
        deactivated(){
            console.log("desactived");

        }
    }
</script>


4. keep-alive重要的兩個(gè)屬性

4.1 組件緩存的問題

講這兩個(gè)重要屬性前,先理解下面幾個(gè)問題

  1. 緩存組件可以提升用戶體驗(yàn),
    • 比如: 登錄輸入的內(nèi)容,當(dāng)切換其他路由再回來是,還保留之前輸?shù)?/li>
  2. 但是有必要所有的組件都需要緩存嗎?
    • 是想一下,如果一個(gè)組件的數(shù)據(jù)需要實(shí)時(shí)跟后臺(tái)數(shù)據(jù)同步,如果被緩存可能就不會(huì)發(fā)送ajax
    • 也就不會(huì)實(shí)時(shí)獲取最新的數(shù)據(jù)
  3. 可以我們也知道,keep-alive包裹的router-view組件位置的所有組件都會(huì)被緩存
  4. 如果喜歡某些組件不需要被緩存應(yīng)該如何處理


4.2 keep-alive兩個(gè)非常重要的屬性:
  1. include 字符串或正則表達(dá)式, 只有匹配的組件會(huì)被緩存
  2. exclude 字符串或正則表達(dá)式,任何匹配成功個(gè)組件都不會(huì)被緩存,用的比較多

示例:

通過組件名來排除一些不需要緩存的組件

<keep-alive exclude="About">
    <router-view></router-view>
</keep-alive>

此時(shí)通過exclude屬性將About組件排除在緩存之外.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末宣决,一起剝皮案震驚了整個(gè)濱河市潮孽,隨后出現(xiàn)的幾起案子辟癌,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喳资,死亡現(xiàn)場離奇詭異檀头,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)坎怪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門罢坝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人搅窿,你說我怎么就攤上這事嘁酿。” “怎么了男应?”我有些...
    開封第一講書人閱讀 165,830評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵闹司,是天一觀的道長。 經(jīng)常有香客問我沐飘,道長游桩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評(píng)論 1 295
  • 正文 為了忘掉前任耐朴,我火速辦了婚禮借卧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘筛峭。我一直安慰自己铐刘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評(píng)論 6 393
  • 文/花漫 我一把揭開白布蜒滩。 她就那樣靜靜地躺著滨达,像睡著了一般奶稠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上捡遍,一...
    開封第一講書人閱讀 51,754評(píng)論 1 307
  • 那天锌订,我揣著相機(jī)與錄音,去河邊找鬼画株。 笑死辆飘,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谓传。 我是一名探鬼主播蜈项,決...
    沈念sama閱讀 40,464評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼续挟!你這毒婦竟也來了紧卒?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤诗祸,失蹤者是張志新(化名)和其女友劉穎跑芳,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體直颅,經(jīng)...
    沈念sama閱讀 45,847評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡博个,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評(píng)論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了功偿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片盆佣。...
    茶點(diǎn)故事閱讀 40,137評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖械荷,靈堂內(nèi)的尸體忽然破棺而出共耍,到底是詐尸還是另有隱情,我是刑警寧澤养葵,帶...
    沈念sama閱讀 35,819評(píng)論 5 346
  • 正文 年R本政府宣布征堪,位于F島的核電站,受9級(jí)特大地震影響关拒,放射性物質(zhì)發(fā)生泄漏佃蚜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評(píng)論 3 331
  • 文/蒙蒙 一着绊、第九天 我趴在偏房一處隱蔽的房頂上張望谐算。 院中可真熱鬧,春花似錦归露、人聲如沸洲脂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽恐锦。三九已至往果,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間一铅,已是汗流浹背陕贮。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留潘飘,地道東北人肮之。 一個(gè)月前我還...
    沈念sama閱讀 48,409評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像卜录,于是被迫代替她去往敵國和親戈擒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容