vue使用keep-alive進行組件緩存方法詳解(組件不緩存問題解決)
一、使用場景
在vue開發(fā)過程中(單頁面),有一些需求需要我們把頁面狀態(tài)保存下來。在切換頁面時,頁面不會進行重新加載。
一般情況下,如果不做特殊處理,會重新執(zhí)行created 和 mounted生命周期,從而重新加載頁面,默認(rèn)就顯示到第一頁去了,就很煩。
(我的問題是,使用keep-alive了,但組件仍然不緩存,下面會解決)
二、 認(rèn)識下keep-alive
- keep-alive是Vue提供的一個內(nèi)置組件,被keep-alive組件包裹的內(nèi)部組件,其狀態(tài)將被緩存
- keep-alive包裹的組件,其生命周期只能被執(zhí)行一次,再次進入時不會被執(zhí)行
- keep-alive包裹的組件,會自動新增兩個生命周期函數(shù)activated和deactivated,每次進入都會被執(zhí)行
activated( ) 當(dāng)keepalive包含的組件再次渲染時觸發(fā)
deactivated( ) 當(dāng)keepalive包含的組件銷毀時觸發(fā) - 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?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ù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07