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

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

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

一、使用場(chǎng)景

在vue開(kāi)發(fā)過(guò)程中(單頁(yè)面),有一些需求需要我們把頁(yè)面狀態(tài)保存下來(lái)。在切換頁(yè)面時(shí),頁(yè)面不會(huì)進(jìn)行重新加載。

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

我的問(wèn)題是,使用keep-alive了,但組件仍然不緩存,下面會(huì)解決

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

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

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

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

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

四、解決組件不緩存問(wèn)題

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

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

下面是代碼分享

主頁(yè)面

//主頁(yè)面
<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>

子頁(yè)面

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

五、keep-alive配合router使用

首先在router中為路由頁(yè)面添加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進(jìn)行組件緩存的文章就介紹到這了,更多相關(guān)vue使用keep-alive組件緩存內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

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

    Vue項(xiàng)目中實(shí)現(xiàn)AES加密解密的全過(guò)程

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

    Vue resource三種請(qǐng)求格式和萬(wàn)能測(cè)試地址

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

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

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

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

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

    解決安裝arco-design-pro-vue失敗問(wèn)題

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

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

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

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

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

    詳解vue-element Tree樹(shù)形控件填坑路

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

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

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

    如何在vue3+ts項(xiàng)目中使用query和params傳參

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

最新評(píng)論