微前端(十)子应用不要写动态load相应js文件

博客讨论了在将应用从常规结构转换为微应用后,动态加载JS文件导致的问题,特别是全局JS的eval错误。提出了三种解决方案:直接在HTML中引入、在main.js中引入或在主应用中加载公共库。如果加载是按钮触发的,建议将JS文件放在主框架并异步加载。
摘要由CSDN通过智能技术生成

sub应用以前写了动态load js文件来实现赖加载,但发现改成微应用后不行了

if ($.fn.zTree == null) {
                //异步加载树对象
            let queryCommand = new QueryCommand(`/static/plugin/jquery.ztree.core.min.js`);
            queryCommand.getScriptAsyncQuery(() => {});
            }

通过异步方式动态来加载ztree的js文件,改成微应用后发现不行了。这里会导致全局js的eval报错啊。

解决方案:

  • 方案1:直接在html文件中引入
    在这里插入图片描述
    -方案2: 在main.js中把文件引入:
    在这里插入图片描述
  • 方案3:如果多个子应用都会用ztree,可以将文件提到主应用中进行加载。个人建议采用方案1

但如果异步加载是通过按钮触发的,则可以把异步js放到主框架,然后异步方式去加载主框架下的全局js,再来进行动态渲染。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值