由于目前 keep-aliverouter-view 是强耦合的,而且查看文档和源码不难发现 keep-aliveinclude (opens new window)默认是优先匹配组件的 name ,所以在编写路由 router 和路由对应的 view component 的时候一定要确保 两者的 name 是完全一致的。(切记 name 命名时候尽量保证唯一性 切记不要和某些组件的命名重复了,不然会递归引用最后内存溢出等问题)
    DEMO:

    1. //router 路由声明
    2. {
    3. path: 'config',
    4. component: ()=>import('@/views/system/config/index'),
    5. name: 'Config',
    6. meta: { title: '参数设置', icon: 'edit' }
    7. }
    1. //路由对应的view system/config/index
    2. export default {
    3. name: 'Config'
    4. }

    一定要保证两着的名字相同,切记写重或者写错。默认如果不写 name 就不会被缓存,详情见issue (opens new window)

    提示 在系统管理-菜单管理-可以配置菜单页签是否缓存,默认为缓存

    image.png