vue使用keep-alive進(jìn)行組件緩存方法詳解(組件不緩存問(wè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
- keep-alive是Vue提供的一個(gè)內(nèi)置組件,被keep-alive組件包裹的內(nèi)部組件,其狀態(tài)將被緩存
- keep-alive包裹的組件,其生命周期只能被執(zhí)行一次,再次進(jìn)入時(shí)不會(huì)被執(zhí)行
- 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ā) - 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)文章希望大家以后多多支持腳本之家!
- Vue中Keep-Alive緩存組件使用語(yǔ)法及原理深度解析
- Vue3除了keep-alive還有哪些實(shí)現(xiàn)頁(yè)面緩存詳解
- React實(shí)現(xiàn)頁(yè)面狀態(tài)緩存(keep-alive)的示例代碼
- Vue路由組件的緩存keep-alive和include屬性的具體使用
- Vue keep-alive組件的使用及如何清除緩存
- vue3?keep-alive實(shí)現(xiàn)tab頁(yè)面緩存功能
- Vue3嵌套路由中使用keep-alive緩存多層的實(shí)現(xiàn)
- vue中keep-alive組件實(shí)現(xiàn)多級(jí)嵌套路由的緩存
- 快速解決 keep-alive 緩存組件中定時(shí)器干擾問(wèn)題
相關(guān)文章
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-08Vue resource三種請(qǐng)求格式和萬(wàn)能測(cè)試地址
這篇文章主要介紹了Vue-resource三種請(qǐng)求格式和萬(wàn)能測(cè)試地址,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09Vue?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ù),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07解決安裝arco-design-pro-vue失敗問(wèn)題
這篇文章主要為大家介紹了解決安裝arco-design-pro-vue失敗的問(wèn)題方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11詳解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如何在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