最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 一劳永逸,解决基于 keep-alive 的后台多级路由缓存问题

    正文概述 掘金(Hooray)   2020-12-22   782

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

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

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

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

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

    一劳永逸,解决基于 keep-alive 的后台多级路由缓存问题

    解决思路

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

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

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

    // 原始数据(用于侧边栏导航菜单)
    {
        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 进行显示了,所以在处理路由数据的同时,也需要处理面包屑导航的信息。大致最终会处理成这样:

    {
        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 的后台多级路由缓存问题

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元