Vue3-KeepAlive,多個(gè)頁(yè)面使用keepalive方式
Vue3-KeepAlive,多個(gè)頁(yè)面使用keepalive
Vue3的生命周期
未添加keepAlive的生命周期
beforeCreate
=>created
=>beforeMount
=>mounted
=>beforeUpdate
=>updated
=>beforeUnmount
=>unmounted
添加keepAlive的生命周期
activated
:當(dāng)keepalive
包含的組件渲染的時(shí)候觸發(fā)deactived
:當(dāng)keepalive
包含的組件銷毀的時(shí)候觸發(fā)keep-alive
的生命周期activated
: 頁(yè)面第一次進(jìn)入的時(shí)候,鉤子觸發(fā)的順序是created->mounted->activated
deactivated
: 頁(yè)面退出的時(shí)候會(huì)觸發(fā)deactivated
當(dāng)再次前進(jìn)或者后退的時(shí)候只觸發(fā)activated
在VueApp中配合vue-router使用keepalive
上一節(jié)了解到keepalive的生命周期后,大致就可以理解keepalive的意義,用于緩存頁(yè)面信息,不重復(fù)渲染同樣的內(nèi)容。
可配合vue-router路由使用keepalive,在路由組件配置文件當(dāng)中配置組件是否需要被緩存
配置meta屬性,以Home組件為例,配置meta.keepAlive為true
{//主頁(yè) path: '/', name: 'Home', component: () => import(/* webpackChunkName: "about" */ '../views/Home.vue'), meta: { title: 'Home', keepAlive: true }, beforeRouteLeave: (to, from, next) => { console.log(to.meta); } }
在根組件App.vue中使用keep-alive標(biāo)簽包含需要緩存的組件,這里根據(jù)$router.meta.keepAlive屬性判斷是否緩存
<!-- 這是vue3的寫法,與vue2的寫法有所區(qū)別,如果這里使用vue2.x寫法,會(huì)有警告 --> <router-view v-slot="{ Component }"> <keep-alive> <component :is="Component" :key="$route.name" v-if="$route.meta.keepAlive" /> </keep-alive> <component :is="Component" :key="$route.name" v-if="!$route.meta.keepAlive" /> </router-view>
請(qǐng)注意上述代碼當(dāng)中有:key屬性,通常多個(gè)頁(yè)面會(huì)使用到keepAlive屬性,如果是多個(gè)頁(yè)面,那么必須加上:key屬性,否則會(huì)報(bào)錯(cuò)。
效果圖(首頁(yè)及mv頁(yè)不會(huì)重新加載)
Vue2和Vue3的keep-alive用法
vue3的keep-alive用法和vue2用法是不同的。
vue2 keep-alive
keep-alive概念:
keep-alive是Vue的內(nèi)置組件,當(dāng)它包裹動(dòng)態(tài)組件時(shí),會(huì)緩存不活動(dòng)的組件實(shí)例,而不是銷毀。
keep-alive作用:
用來緩存組件,避免多次加載相同的組件,減少性能消耗,提高用戶體驗(yàn)。
keep-alive使用方式:
方式一:在App.vue中使用keep-alive標(biāo)簽,表示緩存所有頁(yè)面
<div id="app"> <keep-alive> <tar-bar></tar-bar> <div class="container"> <left-menu></left-menu> <Main /> </div> </keep-alive> </div>
方式二:按條件緩存,使用include,exclude判斷是否緩存
// 1. 將緩存 name 為 cc 的組件,如果有多個(gè),可用逗號(hào)分 <keep-alive include='cc,cc1,cc2'> <router-view/> </keep-alive> // 2. 將不緩存 name 為 cc 的組件 <keep-alive exclude='cc'> <router-view/> </keep-alive> // 3. 還可使用屬性綁定動(dòng)態(tài)判斷 <keep-alive :include='includedComs'> <router-view/> </keep-alive>
方式三:在router目錄下的index.js中,
第一步:使用meta:{keepAlive = true },表示需要緩存
const routes = [ { path:'/', component:Home, meta:{ keepalive:true } }, { path:'/login', component:Login }, { path:'/edit', component:Edit, meta:{ istoken: true } }, { path:'/home', component:Home, meta:{ keepalive:true } } ]
第二步:在App.vue中進(jìn)行判斷
<div id="app"> <!--keep-alive 表示頁(yè)面不會(huì)被銷毀,即保持頁(yè)面狀態(tài)--> <keep-alive> <router-view v-if="$route.meta.keepalive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepalive"></router-view> </div>
vue3中 keep-alive
1基本用法(通過插槽)
<router-view v-slot="{ Component }"> <keep-alive> <component :is="Component"/> </keep-alive> </router-view>
2條件緩存(通過插槽的方式)
示例:列表頁(yè)面跳轉(zhuǎn)到詳情頁(yè)面的情況,保證上一級(jí)頁(yè)面的頁(yè)面數(shù)據(jù)不會(huì)刷新,例如兩個(gè)頁(yè)面A頁(yè)面—>>>列表頁(yè),B頁(yè)面—>>>詳情頁(yè),A–>>B–>>A ,緩存A頁(yè)面的數(shù)據(jù)
<template> <router-view v-slot="{ Component }"> <keep-alive :include="includeList"> <component :is="Component"/> </keep-alive> </router-view> </template>
<script> import { reactive, watch, toRefs } from '@vue/runtime-core' import { useRoute, useRouter } export default { name: 'Test', setup(){ const state = reactive({ includeList: [] }) const route = useRoute() // const router = useRouter() watch(() => route,(newVal,oldVal)=>{ if(newVal.meta.keepAlive && state.includeList.indexOf(newVal.name) === -1){ state.includeList.push(newVal.name); console.log(state.includeList); } },{deep:true}) // 開啟深度監(jiān)聽 return{ ...toRefs(state) } } } </script>
路由頁(yè)面的配置
{ path: 'test', name: 'Test', component: () => import('@/views/Test'), meta: { keepAlive: true, // 組件需要緩存 } },
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue中input標(biāo)簽上傳本地文件或圖片后獲取完整路徑的解決方法
本文給大家介紹vue中input標(biāo)簽上傳本地文件或圖片后獲取完整路徑,如E:\medicineOfCH\stageImage\xxx.jpg,本文給大家分享完美解決方案,感興趣的朋友跟隨小編一起看看吧2023-04-04Vue和React中快速使用Electron的簡(jiǎn)單教程
Electron也可以快速地將你的網(wǎng)站打包成一個(gè)原生應(yīng)用發(fā)布,下面這篇文章主要給大家介紹了關(guān)于Vue和React中快速使用Electron的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05VUE項(xiàng)目實(shí)現(xiàn)全屏顯示功能之screenfull用法
這篇文章主要介紹了VUE項(xiàng)目實(shí)現(xiàn)全屏顯示功能之screenfull用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01