美文网首页
qiankun + vue 中使用 keep-alive 维持微

qiankun + vue 中使用 keep-alive 维持微

作者: copyLeft | 来源:发表于2021-02-22 18:26 被阅读0次
    image.png

    背景

    qiankun + vue2.6 + element-ui, 通过标签却换不同功能, 当前一个子应用下可以对应多个功能, 及 存在统一应用下切换,跨应用切换。 当前已通过路由嵌套实现子应用独立管理各自路由,主应用负责跨应该路由切换。子应用使用手动加载。

    目的

    • 同时维持多个子应用实例
    • 应用切换不丢失
    • 加载失败时,可二次重载
    • 需要同时维持多个子应用实例
    • 子应用加载成功后切换不丢失
    • 子应用加载失败后可重载

    问题

    • 手动加载子应用失败后,二次加载乾坤未重载的应用
    • 子应用切换后将丢失,造成多次需要重复加载
    • 初始加载时间过长

    主要的目的是尽量减少子应用的二次加载,避免资源的重复请求.

    方案

    触发重载

    image.png

    加载失败后,我们需要用户再次开启功能时,进行重载。 而qiankun当前对统一子应用做的缓存处理,首先需要触发qiankun 重载。参考
    这里在构建配置文件时,为请求地址添加一个更新编号, 当需要重载时,更新该编号, 再次手动加载时,将触发子应用的二次加载.

    维持实例

    这里通过keep-alive 保存我们子应用实例。需要解决的问题是,当应用加载失败时, 我们需要通知keep-alive 排除之前保存的实例对象。 所以需要设置 exclude 属性. 加载子应用时,监听加载结果。成功: exclude 组件名出栈, 失败:exclude 组件名入栈.


    image.png
    image.png
    image.png

    需要注意的是, keep-alive 是通过组件名称判断缓存的, 所以在加载前,我们需要先为每个子应用分配独立的组件并注册到容器组件中.

    相关文章

      网友评论

          本文标题:qiankun + vue 中使用 keep-alive 维持微

          本文链接:https://www.haomeiwen.com/subject/cuukfltx.html