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

vue使用keep-alive進行組件緩存方法詳解(組件不緩存問題解決)

 更新時間:2022年09月21日 11:03:30   作者:pipizhou16  
keep-alive包裹動態(tài)組件時,會緩存不活動的組件實例,而不是銷毀它們,下面這篇文章主要給大家介紹了關(guān)于vue使用keep-alive進行組件緩存方法(組件不緩存問題解決)的相關(guān)資料,需要的朋友可以參考下

一、使用場景

在vue開發(fā)過程中(單頁面),有一些需求需要我們把頁面狀態(tài)保存下來。在切換頁面時,頁面不會進行重新加載。

一般情況下,如果不做特殊處理,會重新執(zhí)行created 和 mounted生命周期,從而重新加載頁面,默認(rèn)就顯示到第一頁去了,就很煩。

我的問題是,使用keep-alive了,但組件仍然不緩存,下面會解決

二、 認(rèn)識下keep-alive

  1. keep-alive是Vue提供的一個內(nèi)置組件,被keep-alive組件包裹的內(nèi)部組件,其狀態(tài)將被緩存
  2. keep-alive包裹的組件,其生命周期只能被執(zhí)行一次,再次進入時不會被執(zhí)行
  3. keep-alive包裹的組件,會自動新增兩個生命周期函數(shù)activated和deactivated,每次進入都會被執(zhí)行
    activated( ) 當(dāng)keepalive包含的組件再次渲染時觸發(fā)
    deactivated( ) 當(dāng)keepalive包含的組件銷毀時觸發(fā)
  4. keep-alive兩個屬性include和exclude,可以讓keep-alive實現(xiàn)有條件的進行緩存。include匹配到的組件會被進行緩存,exclude匹配到的組件不會被緩存

三、在組件中應(yīng)用

//第一種:直接在組件外面套keep-alive 組件A和組件B內(nèi)容都會被緩存
    <keep-alive>
      <component :is="comName"></component>
    </keep-alive>
 
//第二種:include 此時只有組件A內(nèi)容會被緩存 若有多個可用逗號分隔include="ReportA,ReportB"
      <keep-alive include="ReportA">
         <component :is="comName"></component> 
      </keep-alive>
 
//第三種:include+正則表達式或者數(shù)組 這種情況必須用v-bind (:include="")
      <keep-alive :include="['ReportA']">
         <component :is="comName"></component>
      </keep-alive> 
 
//第四種:exclude 此時組件A內(nèi)容不會被緩存,組件B內(nèi)容會被緩存
      <keep-alive exclude="ReportA">
         <component :is="comName"></component>
      </keep-alive> 
 
 
//特殊情況:若include和exclude同時出現(xiàn) exclude的優(yōu)先級是高于include的此時只緩存組件B
      <keep-alive include="ReportA,ReportB" exclude="ReportA">
         <component :is="comName"></component>
      </keep-alive> 
// 如果緩存的組件超過了max設(shè)定的值5,那么將刪除第一個緩存的組件
	  <keep-alive exclude="c" max="5">
	     <component />
	  </keep-alive>

參考鏈接:http://www.dbjr.com.cn/article/263316.htm

四、解決組件不緩存問題

我寫了兩個組件,一個房態(tài)的,一個列表,需要動態(tài)切換。
組件切換沒問題,但每次都要加載created 和 mounted生命周期。 (我搜索了下原因,都沒用,后來又看了遍代碼,突然發(fā)現(xiàn)問題)

原因: 主要是引入的組件,export default{ } 默認(rèn)輸出,忘寫名字。

下面是代碼分享

主頁面

//主頁面
<template>
      <keep-alive include="ReportA,ReportB">
        <component :is="comName" > </component>
      </keep-alive>
</template>
<script>
import ReportA from './components/reportA.vue'
import ReportB from './components/reportB.vue'
export default {
  components: {
    ReportA,
    ReportB,
  },
}
</script>

子頁面

<script>
export default {
  name: 'ReportA',    //需要默認(rèn)輸出的名字(兩個頁面都要)
}
</script>

五、keep-alive配合router使用

首先在router中為路由頁面添加meta屬性:

{
    path: '/tab',
    name: 'tab',
    meta:{
      keepAlive:true   //需要緩存
    },
    component: () => import('../views/Tab.vue')
  },
  {
    path: '/banner',
    name: 'banner',
    meta:{
      keepAlive:false   //不需要緩存
    },
    component: () => import('../views/Banner.vue')
  }

然后在App.vue中添加判斷:

    //此處是為添加了keepAlive=true 的路由添加緩存
     <keep-alive>
        <router-view v-if="$route.meta.keepAlive"/>   
     </keep-alive>
 
    //此處是為添加了keepAlive=false 的路由默認(rèn)不緩存
      <router-view v-if="!$route.meta.keepAlive"/>   

總結(jié)

到此這篇關(guān)于vue使用keep-alive進行組件緩存的文章就介紹到這了,更多相關(guān)vue使用keep-alive組件緩存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue項目中實現(xiàn)AES加密解密的全過程

    Vue項目中實現(xiàn)AES加密解密的全過程

    AES算法是一種對稱加密算法,用于加密和解密數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Vue項目中實現(xiàn)AES加密解密的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08
  • Vue resource三種請求格式和萬能測試地址

    Vue resource三種請求格式和萬能測試地址

    這篇文章主要介紹了Vue-resource三種請求格式和萬能測試地址,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • Vue?3?表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程

    Vue?3?表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程

    本文給大家介紹Vue3表單與后端數(shù)據(jù)交互之查詢并回顯數(shù)據(jù)步驟流程,結(jié)合實例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • 詳解vue express啟動數(shù)據(jù)服務(wù)

    詳解vue express啟動數(shù)據(jù)服務(wù)

    本篇文章主要介紹了vue express啟動數(shù)據(jù)服務(wù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 解決安裝arco-design-pro-vue失敗問題

    解決安裝arco-design-pro-vue失敗問題

    這篇文章主要為大家介紹了解決安裝arco-design-pro-vue失敗的問題方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Vue頂部tags瀏覽歷史的實現(xiàn)

    Vue頂部tags瀏覽歷史的實現(xiàn)

    在管理系統(tǒng)中,常常需要在頂部tags顯示瀏覽歷史。本文將教大家如何通過Vue實現(xiàn)這一功能,文中的示例代碼講解詳細(xì),需要的可以參考一下
    2021-12-12
  • 前端Vue如何獲取登錄的用戶名或用戶id代碼實例

    前端Vue如何獲取登錄的用戶名或用戶id代碼實例

    在前端開發(fā)中,獲取登錄用戶的用戶名是一項常見的需求,這篇文章主要給大家介紹了關(guān)于前端Vue如何獲取登錄的用戶名或用戶id的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-07-07
  • 詳解vue-element Tree樹形控件填坑路

    詳解vue-element Tree樹形控件填坑路

    這篇文章主要介紹了vue-element Tree樹形控件填坑路,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 基于vue2實現(xiàn)左滑刪除功能

    基于vue2實現(xiàn)左滑刪除功能

    這篇文章主要為大家詳細(xì)介紹了基于vue2實現(xiàn)左滑刪除功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 如何在vue3+ts項目中使用query和params傳參

    如何在vue3+ts項目中使用query和params傳參

    Vue3中的路由傳參有兩種方式:query和params,下面這篇文章主要給大家介紹了關(guān)于如何在vue3+ts項目中使用query和params傳參的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04

最新評論