gpt4 book ai didi

解决基于 keep-alive 的后台多级路由缓存问题

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 31 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章解决基于 keep-alive 的后台多级路由缓存问题由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

用过 vue-element-admin 的同学一定很清楚,路由的配置直接关系侧边栏导航菜单的展示,也得益于这种设计思路,几乎大部分后台框架都采用这个方案,当然也包括了我写的 Fantastic-admin 这个中后台框架.

但这个方案有个明显的问题,就是为了实现多级侧边栏导航菜单,则需要将路由配置成多级嵌套的形式,一旦超过两级,达到三级甚至更多级,就需要增加一个空布局页面(Empty.vue)用来给 component 使用,仅仅是为了生成层级菜单。此时就出现了一个问题,因为 keep-alive 是在 Layout 上处理的,所以超过两级以上的路由都会变得难以处理,也没有一个相对完美的解决方案.

在思考并解决这个问题之前,我们先来看下页面大致结构:

?
1
2
3
4
5
6
7
8
9
+------------------------------+
| Layout            |
| +------------------------+ |
| | Empty         | |
| | +------------------+ | |
| | | Page       | | |
| | +------------------+ | |
| +------------------------+ |
+------------------------------+

首先 keep-alive 是在 Layout 上进行处理,如果不缓存 Empty ,则 Empty 下面的页面将无法被缓存,如果缓存 Empty ,又会导致 Empty 里面的所有页面都被缓存,无法按需清除,相信接触过的同学肯定感同身受其中的大坑.

解决基于 keep-alive 的后台多级路由缓存问题

解决思路

其实有一个相对清晰简单的解决思路,既然缓存二级路由是没问题,而超过二级的中间层级页面也是没太大意义的,那为什么不将路由直接处理成二级,这样页面显示也就是二级的结构.

?
1
2
3
4
5
6
7
8
9
+------------------------------+        +------------------------------+
| Layout            |        | Layout.vue          |
| +------------------------+ |        | +------------------------+ |
| | Empty         | | +----------> | | Page          | |
| | +------------------+ | |        | |            | |
| | | Page       | | |        | |            | |
| | +------------------+ | |        | |            | |
| +------------------------+ |        | +------------------------+ |
+------------------------------+        +------------------------------+

这里需要注意,路由配置还是保持多级嵌套的形式,而这个配置并非最终注册使用的路由,仅仅是提供侧边栏导航菜单使用,同时再生成一份用于动态注册路由的数据,图例如果没看明白的话,可以看下面两组数据.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// 原始数据(用于侧边栏导航菜单)
{
   path: '/users' ,
   meta: {
     title: '用户管理'
   },
   children: [
     {
       path: 'clients' ,
       meta: {
         title: '客户管理'
       },
       children: [
         {
           path: 'list' ,
           meta: {
             title: '客户列表'
           }
         },
         {
           path: 'detail' ,
           meta: {
             title: '客户详情'
           }
         }
       ]
     }
   ]
}
 
// 处理后数据(用于动态注册路由)
{
   path: '/users' ,
   meta: {
     title: '用户管理'
   },
   children: [
     {
       path: 'clients/list' ,
       meta: {
         title: '客户列表'
       }
     },
     {
       path: 'clients/detail' ,
       meta: {
         title: '客户详情'
       }
     }
   ]
}

通过一个递归函数就可以处理好路由的数据,但这还不够,因为还需要处理面包屑导航.

原有的面包屑导航是通过 $route.matched 可以获取到嵌套路由每一层级的信息,而当路由被处理成两级后,也就无法通过 $route.matched 进行显示了,所以在处理路由数据的同时,也需要处理面包屑导航的信息。大致最终会处理成这样:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
{
   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 就可以获取任意某个路由的完整面包屑导航信息了。最终效果如下:

解决基于 keep-alive 的后台多级路由缓存问题

通过图片可以看到,这种方案也还是有一定的限制,就是路由被处理成二级后,多级嵌套关系不存在了,也就是不能在 Empty 里写任何代码,因为都会被忽略掉,只保留顶级和最深层的底级两个路由.

当然通过实际情况考虑,这种限制并没有大问题,因为在后台系统里,本身模块相对独立,即便侧边栏导航菜单是嵌套层级关系的,在右侧内容展示区域,几乎都是独立模块展示,无需嵌套.

实例代码

本文主要是讨论实现思路,相关代码可在 Fantastic-admin 里查看,核心代码在这,点击查看.

到此这篇关于解决基于 keep-alive 的后台多级路由缓存问题的文章就介绍到这了,更多相关 keep-alive多级路由缓存 内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://www.cnblogs.com/hooray/archive/2020/12/22/14174402.html 。

最后此篇关于解决基于 keep-alive 的后台多级路由缓存问题的文章就讲到这里了,如果你想了解更多关于解决基于 keep-alive 的后台多级路由缓存问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com