欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中keep-alive組件實現(xiàn)多級嵌套路由的緩存

 更新時間:2022年03月25日 10:59:43   作者:花名森林  
本文主要介紹了vue中keep-alive組件實現(xiàn)多級嵌套路由的緩存,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

現(xiàn)狀(問題):

keep-alive 組件對第三級及以上級的路由頁面緩存失效

探索方案:

方案1、直接將路由扁平化配置,都放在一級或二級路由中
方案2、再一層緩存組件用來過渡,并將其name配置到include中

實現(xiàn)方式

方案1不需要例子,按規(guī)則配置路由就行重點介紹方案2
因為我用了vue-element-admin做了架構(gòu),并且項目中我將菜單和路由全部通過服務(wù)端返回做了統(tǒng)一配置,所以我只能用方案2來實現(xiàn)。

直接看原有代碼(問題代碼)

// src/layout/component/AppMain.vue
<template>
?<section class="app-main">
?? ? ?<transition name="fade-transform" mode="out-in">
?? ??? ? ? <keep-alive :include="cachedViews">
?? ??? ? ? ? ?? ?<router-view :key="key" />
?? ??? ? ? </keep-alive>
?? ? ?</transition>
?</section>
</template>

<script>
export default {
? name: 'AppMain',
? computed: {
? ? cachedViews() {
? ? ? return this.$store.state.tagsView.cachedViews
? ? },
? ? key() {
? ? ? return this.$route.path
? ? }
? }
}
</script>

我從后端那到數(shù)據(jù)后,根據(jù)樹形結(jié)構(gòu)做了處理(在store里寫的,只展示出關(guān)鍵代碼)

// 拿到數(shù)據(jù)先循環(huán)第一層將Layout付給組件
?generateRoutes({ commit }, routeList) {
? ? return new Promise(resolve => {
? ? ? routeList.forEach(items => {
? ? ? ? items.component = Layout
? ? ? ? // 如果有子菜單直接再循環(huán)賦值
? ? ? ? items.children = changeAsyncRoutes(items.children)
? ? ? })
? ? ? commit('SET_ROUTES', routeList)
? ? ? resolve(routeList)
? ? })
? }
function changeAsyncRoutes(routes) {
? const res = []
? routes.forEach(route => {
? ? const tmp = { ...route }
? ? if (tmp.children && tmp.children.length !== 0) {
? ??? ?// 若有子級 先創(chuàng)建router-view容器,再去遞歸(重點重點重點)
? ? ? tmp.component = {
? ? ? ??? ?render: c => c('router-view')
? ? ? }
? ? ? tmp.children = changeAsyncRoutes(tmp.children)
? ? } else {
? ? // 沒有子級菜單直接將component字符串解析成組件對象
? ? ? tmp.component = importMethod(tmp.component)
? ? }
? ? res.push(tmp)
? })
? return res
}

這種寫法已經(jīng)很完美了,可惜,我遇到了三級菜單不能緩存的問題
直接上解決問題的代碼

1、新建MenuMain.vue組件如下

// src/layout/component/MenuMain.vue
// 提供多級菜單的容器
<template>
? <keep-alive :include="cachedViews">
? ? <router-view :key="key" />
? </keep-alive>
</template>

<script>
export default {
? name: 'MenuMain', // 必須命名
? computed: {
? ? cachedViews() {
? ? ? return this.$store.state.tagsView.cachedViews
? ? },
? ? key() {
? ? ? return this.$route.path
? ? }
? }
}
</script>

2、將此容器取代處理數(shù)據(jù)時render的 router-view 容器

// 引入組件
import MenuMain from '@/layout/components/MenuMain'

function changeAsyncRoutes(routes) {
? const res = []
? routes.forEach(route => {
? ? const tmp = { ...route }

? ? if (tmp.children && tmp.children.length !== 0) {
? ? // 注意看著里
? ? ? tmp.component = MenuMain
? ? ? // {
? ? ? // ? render: c => c('router-view')
? ? ? // }
? ? ? tmp.children = changeAsyncRoutes(tmp.children)
? ? } else {
? ? ? tmp.component = importMethod(tmp.component)
? ? }
? ? res.push(tmp)
? })
? return res
}

3、把store中的 cachedViews 數(shù)組中始終保存MenuMain組件的名稱

cachedViews: ['MenuMain'] 

到此這篇關(guān)于vue中keep-alive組件實現(xiàn)多級嵌套路由的緩存的文章就介紹到這了,更多相關(guān)vue keep-alive多級嵌套路由緩存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue項目三級聯(lián)動路由跳轉(zhuǎn)與傳參的思路詳解

    Vue項目三級聯(lián)動路由跳轉(zhuǎn)與傳參的思路詳解

    這篇文章主要介紹了Vue項目三級聯(lián)動的路由跳轉(zhuǎn)與傳參的思路詳解,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • VueJS組件之間通過props交互及驗證的方式

    VueJS組件之間通過props交互及驗證的方式

    本篇文章主要介紹了VueJS組件之間通過props交互及驗證的方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-09-09
  • 淺談vue中改elementUI默認(rèn)樣式引發(fā)的static與assets的區(qū)別

    淺談vue中改elementUI默認(rèn)樣式引發(fā)的static與assets的區(qū)別

    下面小編就為大家分享一篇淺談vue中改elementUI默認(rèn)樣式引發(fā)的static 與assets的區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • 前端報錯npm ERR! cb() never called!問題解決辦法

    前端報錯npm ERR! cb() never called!問題解決辦法

    最近接手了一個前臺項目,執(zhí)行npm install的時候一直報錯,所以這里就給大家總結(jié)下,這篇文章主要給給大家介紹了關(guān)于前端報錯npm?ERR! cb() never called!問題的解決辦法,需要的朋友可以參考下
    2024-05-05
  • vue實現(xiàn)todolist單頁面應(yīng)用

    vue實現(xiàn)todolist單頁面應(yīng)用

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)todolist單頁面應(yīng)用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • vue2項目使用exceljs多表頭導(dǎo)出功能詳解

    vue2項目使用exceljs多表頭導(dǎo)出功能詳解

    ExcelJS是一個用于在Node.js和瀏覽器中創(chuàng)建、讀取和修改Excel文件的強大JavaScript庫,下面這篇文章主要給大家介紹了關(guān)于vue2項目使用exceljs多表頭導(dǎo)出功能的相關(guān)資料,需要的朋友可以參考下
    2024-05-05
  • Vue.js實現(xiàn)點擊左右按鈕圖片切換

    Vue.js實現(xiàn)點擊左右按鈕圖片切換

    這篇文章主要為大家詳細(xì)介紹了Vue.js實現(xiàn)點擊左右按鈕圖片切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue項目中使用Base64

    Vue項目中使用Base64

    在vue項目中有時會使用到Base6464轉(zhuǎn)碼,現(xiàn)將自己使用的一種方法記錄下來,對vue使用Base64相關(guān)知識感興趣的朋友一起看看吧
    2024-02-02
  • vue組件component的注冊與使用詳解

    vue組件component的注冊與使用詳解

    組件是Vue是一個可以重復(fù)使用的Vue實例, 它擁有獨一無二的組件名稱,它可以擴展HTML元素,以組件名稱的方式作為自定義的HTML標(biāo)簽,這篇文章主要介紹了vue組件component的注冊與使用,需要的朋友可以參考下
    2022-08-08
  • vue使用$emit時,父組件無法監(jiān)聽到子組件的事件實例

    vue使用$emit時,父組件無法監(jiān)聽到子組件的事件實例

    下面小編就為大家分享一篇vue使用$emit時,父組件無法監(jiān)聽到子組件的事件實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02

最新評論