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

解決基于 keep-alive 的后臺多級路由緩存問題

 更新時間:2020年12月23日 09:45:28   作者:一個不太知名的程序員  
這篇文章主要介紹了解決基于 keep-alive 的后臺多級路由緩存問題,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

用過 vue-element-admin 的同學一定很清楚,路由的配置直接關系側邊欄導航菜單的展示,也得益于這種設計思路,幾乎大部分后臺框架都采用這個方案,當然也包括了我寫的 Fantastic-admin 這個中后臺框架。

但這個方案有個明顯的問題,就是為了實現多級側邊欄導航菜單,則需要將路由配置成多級嵌套的形式,一旦超過兩級,達到三級甚至更多級,就需要增加一個空布局頁面(Empty.vue)用來給 component 使用,僅僅是為了生成層級菜單。此時就出現了一個問題,因為 keep-alive 是在 Layout 上處理的,所以超過兩級以上的路由都會變得難以處理,也沒有一個相對完美的解決方案。

在思考并解決這個問題之前,我們先來看下頁面大致結構:

+------------------------------+
| Layout            |
| +------------------------+ |
| | Empty         | |
| | +------------------+ | |
| | | Page       | | |
| | +------------------+ | |
| +------------------------+ |
+------------------------------+

首先 keep-alive 是在 Layout 上進行處理,如果不緩存 Empty ,則 Empty 下面的頁面將無法被緩存,如果緩存 Empty ,又會導致 Empty 里面的所有頁面都被緩存,無法按需清除,相信接觸過的同學肯定感同身受其中的大坑。

解決思路

其實有一個相對清晰簡單的解決思路,既然緩存二級路由是沒問題,而超過二級的中間層級頁面也是沒太大意義的,那為什么不將路由直接處理成二級,這樣頁面顯示也就是二級的結構。

+------------------------------+        +------------------------------+
| Layout            |        | Layout.vue          |
| +------------------------+ |        | +------------------------+ |
| | Empty         | | +----------> | | Page          | |
| | +------------------+ | |        | |            | |
| | | Page       | | |        | |            | |
| | +------------------+ | |        | |            | |
| +------------------------+ |        | +------------------------+ |
+------------------------------+        +------------------------------+

這里需要注意,路由配置還是保持多級嵌套的形式,而這個配置并非最終注冊使用的路由,僅僅是提供側邊欄導航菜單使用,同時再生成一份用于動態(tài)注冊路由的數據,圖例如果沒看明白的話,可以看下面兩組數據。

// 原始數據(用于側邊欄導航菜單)
{
  path: '/users',
  meta: {
    title: '用戶管理'
  },
  children: [
    {
      path: 'clients',
      meta: {
        title: '客戶管理'
      },
      children: [
        {
          path: 'list',
          meta: {
            title: '客戶列表'
          }
        },
        {
          path: 'detail',
          meta: {
            title: '客戶詳情'
          }
        }
      ]
    }
  ]
}

// 處理后數據(用于動態(tài)注冊路由)
{
  path: '/users',
  meta: {
    title: '用戶管理'
  },
  children: [
    {
      path: 'clients/list',
      meta: {
        title: '客戶列表'
      }
    },
    {
      path: 'clients/detail',
      meta: {
        title: '客戶詳情'
      }
    }
  ]
}

通過一個遞歸函數就可以處理好路由的數據,但這還不夠,因為還需要處理面包屑導航。

原有的面包屑導航是通過 $route.matched 可以獲取到嵌套路由每一層級的信息,而當路由被處理成兩級后,也就無法通過 $route.matched 進行顯示了,所以在處理路由數據的同時,也需要處理面包屑導航的信息。大致最終會處理成這樣:

{
  path: '/users',
  meta: {
    title: '用戶管理'
  },
  children: [
    {
      path: 'clients/list',
      meta: {
        title: '客戶列表',
        breadCrumb: [
          { path: '/users', title: '用戶管理' },
          { path: 'clients', title: '客戶管理' },
          { path: 'list', title: '客戶列表' }
        ]
      }
    },
    {
      path: 'clients/detail',
      meta: {
        title: '客戶詳情',
        breadCrumb: [
          { path: '/users', title: '用戶管理' },
          { path: 'clients', title: '客戶管理' },
          { path: 'detail', title: '客戶詳情' }
        ]
      }
    }
  ]
}

這樣一來,通過 $route.meta.breadcrumb 就可以獲取任意某個路由的完整面包屑導航信息了。最終效果如下:

通過圖片可以看到,這種方案也還是有一定的限制,就是路由被處理成二級后,多級嵌套關系不存在了,也就是不能在 Empty 里寫任何代碼,因為都會被忽略掉,只保留頂級和最深層的底級兩個路由。

當然通過實際情況考慮,這種限制并沒有大問題,因為在后臺系統里,本身模塊相對獨立,即便側邊欄導航菜單是嵌套層級關系的,在右側內容展示區(qū)域,幾乎都是獨立模塊展示,無需嵌套。

實例代碼

本文主要是討論實現思路,相關代碼可在 Fantastic-admin 里查看,核心代碼在這,點擊查看。

到此這篇關于解決基于 keep-alive 的后臺多級路由緩存問題的文章就介紹到這了,更多相關 keep-alive多級路由緩存 內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關文章

  • 基于Vue實現消息提示功能

    基于Vue實現消息提示功能

    這篇文章主要為大家詳細介紹了如何基于Vue實現簡單的消息提示功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-10-10
  • vue 巧用過渡效果(小結)

    vue 巧用過渡效果(小結)

    這篇文章主要介紹了vue 巧用過渡效果(小結),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • Vue tagsview實現多頁簽導航功能流程詳解

    Vue tagsview實現多頁簽導航功能流程詳解

    基本上后臺管理系統都需要有多頁簽的功能,但是因為一些腳手架項目基本都把這個功能給集成好了,導致在學習或者修改的時候不知道該如何下手。今天這篇文章就來聊一聊,vue-element-admin項目是如何實現多頁簽功能的
    2022-09-09
  • 通過一個簡單的例子學會vuex與模塊化

    通過一個簡單的例子學會vuex與模塊化

    這篇文章主要給大家介紹了關于如何通過一個簡單的例子學會vuex與模塊化的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • van-uploader保存文件到后端回顯后端接口返回的數據

    van-uploader保存文件到后端回顯后端接口返回的數據

    前端開發(fā)想省時間就是要找框架呀,下面這篇文章主要給大家介紹了關于van-uploader保存文件到后端回顯后端接口返回的數據,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • vue側邊欄動態(tài)生成下級菜單的方法

    vue側邊欄動態(tài)生成下級菜單的方法

    今天小編就為大家分享一篇vue側邊欄動態(tài)生成下級菜單的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • VUE解決圖片視頻加載緩慢/首屏加載白屏的問題

    VUE解決圖片視頻加載緩慢/首屏加載白屏的問題

    在 Vue3 項目中,有時候會出現圖片視頻加載緩慢、首屏加載白屏的問題,所以本文小編就給大家詳細介紹一下如何解決圖片視頻加載緩慢/首屏加載白屏的問題,需要的朋友可以參考下
    2023-07-07
  • Vue.js的復用組件開發(fā)流程完整記錄

    Vue.js的復用組件開發(fā)流程完整記錄

    這篇文章主要給大家介紹了關于Vue.js的復用組件開發(fā)流程的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • vue基于vant實現上拉加載下拉刷新的示例代碼

    vue基于vant實現上拉加載下拉刷新的示例代碼

    普遍存在于各種app中的上拉加載下拉刷新功能,本文主要介紹了vue基于vant實現上拉加載下拉刷新,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • vue實現web滾動條分頁

    vue實現web滾動條分頁

    這篇文章主要為大家詳細介紹了vue實現web滾動條分頁,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04

最新評論