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

詳解Vue中組件的緩存

 更新時(shí)間:2019年04月20日 14:37:33   作者:六小登登  
這篇文章主要介紹了Vue中組件的緩存,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

之前在《Vue一個(gè)案例引發(fā)的動(dòng)態(tài)組件與全局事件綁定總結(jié)》這篇文章中簡(jiǎn)單提到過組件的緩存。當(dāng)時(shí)只是簡(jiǎn)單的提供了一個(gè)解決問題的思路,并沒有說到多少組件緩存的東西,今天我們就來詳細(xì)說說組件的緩存。

組件化開發(fā)模式下,我們會(huì)把整個(gè)項(xiàng)目拆分成很多組件,然后按照合理的方式組織起來。

自然就存在組件之間的切換問題,Vue 中有個(gè)「動(dòng)態(tài)組件」的概念,它能夠讓我們更好的實(shí)現(xiàn)組件的切換。

在實(shí)際的項(xiàng)目開發(fā)中,產(chǎn)品是不可能放過我們的,需求總是在不停的變化,如果你碰到那些不改需求的產(chǎn)品就嫁了吧,太難得了。

最近項(xiàng)目中需要實(shí)現(xiàn)一個(gè)保留上一次Tab 頁(yè)的功能。如下圖,當(dāng)我選擇 B 組件時(shí),我希望從首頁(yè)切換到設(shè)置頁(yè)時(shí),還會(huì)停留在 B 組件,而不是重新渲染為默認(rèn)的 A 組件。

首先我們可以使用內(nèi)置組件 <component>實(shí)現(xiàn)動(dòng)態(tài)組件的效果。

<template>
 <div>
   <button
    v-for="tab in tabs"
    :key="tab"
    @click="currentTab = tab"
   ></button>
  <component :is="currentTab"></component>
 </div>
</template>
<script>
export default {
 name: "Tab",
 data() {
  return {
   currentTab: "A",
   tabs: ['A','B']
  };
 }
};
</script>

這時(shí),我們做到了兩個(gè)組件之間的切換,但動(dòng)態(tài)組件在切換的過程中,組件的實(shí)例都是「重新創(chuàng)建」的,而我們需要保留組件狀態(tài)。

為了解決這個(gè)問題,你還需要使用 vue 內(nèi)置組件 <keep-alive>。

keep-alive

keep-alive 包裹「動(dòng)態(tài)組件」時(shí),會(huì)緩存不活動(dòng)的組件實(shí)例,而不是銷毀它們。它是一個(gè)抽象的組件,它自身不會(huì)渲染成一個(gè) DOM 元素,也不會(huì)出現(xiàn)在父組件鏈中。

值得注意的是 「動(dòng)態(tài)組件」這四個(gè)字,它只有在包含動(dòng)態(tài)組件時(shí),才會(huì)產(chǎn)生效果。如果不是動(dòng)態(tài)組件則會(huì)無效。比如下面這種用法是沒有效果的。

<keep-alive>
  <my-component></my-component>
</keep-alive>

既然如此,我們來看看 keep-alive 常用的幾種方式:

方案一: 使用內(nèi)置組件 <component>。

<keep-alive>
 <component :is="view"></component>
</keep-alive>

方案二: 當(dāng)出現(xiàn)條件判斷時(shí)的子組件

<keep-alive>
 <comp-a v-if="a > 1"></comp-a>
 <comp-b v-else></comp-b>
</keep-alive>

方案三: 結(jié)合路由使用時(shí)

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

以上三種方式組件都會(huì)被緩存。另外一點(diǎn)需要注意的是,<keep-alive> 只能用在只有一個(gè)子組件的情況。如果你在其中有 v-for 則不會(huì)產(chǎn)生效果。

明白了如何使用 <keep-alive> 時(shí),想要保留我們的 Tab 頁(yè),我們只需這么做即可。

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

但是這里你會(huì)發(fā)現(xiàn),我們把每一個(gè)組件都緩存了起來,不僅案例中的「設(shè)置頁(yè)」被緩存連「首頁(yè)」也一起被緩存了起來,這不是我們想要的。

vue 幫我們也考慮到了這一點(diǎn),所以我們可以選擇性的進(jìn)行組件的緩存,也就是說你想讓誰(shuí)緩存,就讓誰(shuí)緩存,非常的自由與可配置。

原因是因?yàn)?<keep-alive> 提供了兩個(gè)屬性 include 與 exclude。

  1. include:只有名稱匹配的組件會(huì)被緩存。
  2. exclude:任何名稱匹配的組件都不會(huì)被緩存。

 二者都可以用逗號(hào)分隔字符串、正則表達(dá)式或一個(gè)數(shù)組來表示。

<keep-alive include="a,b"></keep-alive>
<keep-alive :include="/a|b/"></keep-alive>
<keep-alive :include="['a', 'b']"></keep-alive>

所以,結(jié)合 <keep-alive> 的 include 或 exclude屬性,我們就可以輕易的選擇需要緩存的組件。

<keep-alive include="system">
  <router-view></router-view>
</keep-alive>

這樣我們就可以只緩存「設(shè)置頁(yè)」,然后實(shí)現(xiàn)保留上次選擇的 Tab 頁(yè)。

以上所述是小編給大家介紹的Vue中組件的緩存詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • ant-design-vue中的table自定義格式渲染解析

    ant-design-vue中的table自定義格式渲染解析

    這篇文章主要介紹了ant-design-vue中的table自定義格式渲染,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue Render函數(shù)創(chuàng)建DOM節(jié)點(diǎn)代碼實(shí)例

    Vue Render函數(shù)創(chuàng)建DOM節(jié)點(diǎn)代碼實(shí)例

    這篇文章主要介紹了Vue Render函數(shù)創(chuàng)建DOM節(jié)點(diǎn)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Vue中的基礎(chǔ)過渡動(dòng)畫及實(shí)現(xiàn)原理解析

    Vue中的基礎(chǔ)過渡動(dòng)畫及實(shí)現(xiàn)原理解析

    這篇文章主要介紹了Vue中的基礎(chǔ)過渡動(dòng)畫原理解析,需要的朋友可以參考下
    2018-12-12
  • vue .sync修飾符的使用詳解

    vue .sync修飾符的使用詳解

    這篇文章主要介紹了vue .sync修飾符的使用,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • 解決Vue-cli3沒有vue.config.js文件夾及配置vue項(xiàng)目域名的問題

    解決Vue-cli3沒有vue.config.js文件夾及配置vue項(xiàng)目域名的問題

    這篇文章主要介紹了解決Vue-cli3沒有vue.config.js文件夾及配置vue項(xiàng)目域名的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • vue3監(jiān)聽resize窗口事件(離開頁(yè)面要銷毀窗口事件)

    vue3監(jiān)聽resize窗口事件(離開頁(yè)面要銷毀窗口事件)

    這篇文章主要給大家介紹了關(guān)于vue3監(jiān)聽resize窗口事件(離開頁(yè)面要銷毀窗口事件)的相關(guān)資料,vue是單頁(yè)面應(yīng)用,路由切換后,定時(shí)器并不會(huì)自動(dòng)關(guān)閉,需要手動(dòng)清除,當(dāng)頁(yè)面被銷毀時(shí),清除定時(shí)器即可,需要的朋友可以參考下
    2023-11-11
  • 詳解uniapp的生命周期

    詳解uniapp的生命周期

    這篇文章主要介紹了uniapp的生命周期,應(yīng)用生命周期是指應(yīng)用程序從啟動(dòng)到關(guān)閉的整個(gè)過程,包括應(yīng)用程序的啟動(dòng)、前后臺(tái)切換、退出等,需要的朋友可以參考下
    2023-04-04
  • vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明

    vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明

    這篇文章主要介紹了vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue項(xiàng)目中使用rem替換px的實(shí)現(xiàn)示例

    vue項(xiàng)目中使用rem替換px的實(shí)現(xiàn)示例

    移動(dòng)端頁(yè)面適配,rem和vw適配方案,本文主要介紹了vue項(xiàng)目中使用rem替換px的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • vue3結(jié)合typescript中使用class封裝axios

    vue3結(jié)合typescript中使用class封裝axios

    這篇文章主要為大家介紹了vue3結(jié)合typescript中使用class封裝axios實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06

最新評(píng)論