vue3中使用keepAlive緩存路由組件不生效的問題解決
問題出現(xiàn)原因
在router.js
中注冊路由:
{ path: '/template-allocation', name: 'TemplateAllocation', meta: { title: '風險任務(wù)詳情', 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
?。。?br />而是組件本身的name
,記得在vue2
中的時候,export default
中有個屬性可以聲明name
,但是在vue3
中的setup
語法糖中,很少關(guān)注如何聲明name
。
官網(wǎng)有這么一句話:
可是我自己在整理目錄結(jié)構(gòu)的時候,習慣將目錄這樣設(shè)置:/template-allocation/index.vue
,這樣就會導(dǎo)致自動生成的name
變成了Index
!
就會導(dǎo)致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導(dǎo)入scss樣式
這篇文章主要為大家介紹了Vite3結(jié)合Svelte3使用@import導(dǎo)入scss樣式實現(xiàn)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06Vite結(jié)合whistle實現(xiàn)一勞永逸開發(fā)環(huán)境代理方案
這篇文章主要為大家介紹了Vite結(jié)合whistle實現(xiàn)一勞永逸開發(fā)環(huán)境代理方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07Vue3+axios+Mock.js實現(xiàn)登錄功能的示例代碼
本文主要介紹了Vue3+axios+Mock.js實現(xiàn)登錄功能的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2023-05-05詳解在vue-cli項目中使用mockjs(請求數(shù)據(jù)刪除數(shù)據(jù))
本篇文章主要介紹了在vue-cli項目中使用mockjs(請求數(shù)據(jù)刪除數(shù)據(jù)),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10