vue3中使用keepAlive緩存路由組件不生效的問題解決
問題出現(xiàn)原因
在router.js中注冊路由:
{
path: '/template-allocation',
name: 'TemplateAllocation',
meta: { title: '風險任務詳情', keepAlive: true },
component: () =>
import(
'../views/template-allocation/index.vue'
),
},在router-view中使用keepAlive緩存組件:
<router-view v-slot="{ Component }" v-if="isShow">
<div class="child-view">
<KeepAlive :include="['TemplateAllocation']">
<component :is="Component"></component>
</KeepAlive>
</div>
</router-view>最后發(fā)現(xiàn)并不生效,在大佬的幫助下,才找到原因:include中使用的name并不是注冊的路由的name!??!
而是組件本身的name,記得在vue2中的時候,export default中有個屬性可以聲明name,但是在vue3中的setup語法糖中,很少關(guān)注如何聲明name。
官網(wǎng)有這么一句話:

可是我自己在整理目錄結(jié)構(gòu)的時候,習慣將目錄這樣設(shè)置:/template-allocation/index.vue,這樣就會導致自動生成的name變成了Index!
就會導致keepAlice的include屬性不生效了。
如何查找我們的組件名稱呢?
這就要借助一個常用工具Vue Devtools,如下:

從上圖可以看到Index就是我們的組件名字了。
setup中如何設(shè)置組件的名字呢?
官網(wǎng)提供了一個defineOptions,可以這么設(shè)置:
defineOptions({
name: 'TemplateAllocation'
})從Vue Devtools可以看到組件名字變成了TemplateAllocation,如下:

以上就是本次的分享內(nèi)容了,又踩了一個小坑。奉上當初提問的地址。
到此這篇關(guān)于vue3中使用keepAlive緩存路由組件不生效的情況記錄的文章就介紹到這了,更多相關(guān)vue keepAlive不生效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vite3結(jié)合Svelte3使用@import導入scss樣式
這篇文章主要為大家介紹了Vite3結(jié)合Svelte3使用@import導入scss樣式實現(xiàn)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06
Vite結(jié)合whistle實現(xiàn)一勞永逸開發(fā)環(huán)境代理方案
這篇文章主要為大家介紹了Vite結(jié)合whistle實現(xiàn)一勞永逸開發(fā)環(huán)境代理方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
Vue3+axios+Mock.js實現(xiàn)登錄功能的示例代碼
本文主要介紹了Vue3+axios+Mock.js實現(xiàn)登錄功能的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-05-05
詳解在vue-cli項目中使用mockjs(請求數(shù)據(jù)刪除數(shù)據(jù))
本篇文章主要介紹了在vue-cli項目中使用mockjs(請求數(shù)據(jù)刪除數(shù)據(jù)),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10

