使用XSwitch代理微前端基座项目,如何保持微应用热更新

公司采用微前端方式已经有段时间了,一直有个开发问题没解决。当在基座页面使用XSwitch拦截相关 js 和 css 文件到本地的微应用项目时,热更新就会失效,以 ice3 项目为例:

看到这种报错其实就是webSocket服务器没有正确连接到微应用上去,我们只要想办法指定下开发环境的webSocket服务器 URL 就好了。还是以 ice3 为例:

ice3 是基于 webpack5 的,其实官网有介绍

大概这么配置就好了,我们只更改hostname就可以了,其他保持不动,当然你如果是基于 umi 的,就找 umi 修改websocketurl的方式,反正大同小异
指定好后重启下微应用,发现不报错了
但是当你修改一下后又报错了
这个报错是因为hot-update.json没有被正确的请求到,我们打开浏览器控制台,找到网络可以看到请求
此时你可以直接使用XSwitch拦截这个请求重定向到本地微应用去,例如:
当然 umi 的也可以用其他方式实现,比如修改SOCKET_SERVER这个环境变量等
当这一切的一切都改好后,就不会报错了,此时你可能可以热更新了,但是有些情况下,还是不能热更新

那是因为微应用的react被externals出去了,统一使用了基座项目里的 react,而基座的 react 往往使用了生产版本的 react,我们知道,react 的热更新是需要开发版本的 react 和 React Developer Tools 这个浏览器插件的,这两者缺一不可,不然是无法热更新的。所以此时的解决方法:

  1. 部署一个基于开发版的 react 的基座项目
  2. 不要在开发的时候把微应用的 react externals出去
如果还有更好的方法,可以留言哦,大家一起集思广益
相关推荐
我爱加班、、4 分钟前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao4 分钟前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly11 分钟前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
hedley(●'◡'●)40 分钟前
基于cesium和vue的大疆司空模仿程序
前端·javascript·vue.js·python·typescript·无人机
qq5_81151751542 分钟前
web城乡居民基本医疗信息管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
百思可瑞教育43 分钟前
构建自己的Vue UI组件库:从设计到发布
前端·javascript·vue.js·ui·百思可瑞教育·北京百思教育
百锦再43 分钟前
Vue高阶知识:利用 defineModel 特性开发搜索组件组合
前端·vue.js·学习·flutter·typescript·前端框架
CappuccinoRose1 小时前
JavaScript 学习文档(二)
前端·javascript·学习·数据类型·运算符·箭头函数·变量声明
这儿有一堆花1 小时前
Vue 是什么:一套为「真实业务」而生的前端框架
前端·vue.js·前端框架
全栈前端老曹1 小时前
【MongoDB】深入研究副本集与高可用性——Replica Set 架构、故障转移、读写分离
前端·javascript·数据库·mongodb·架构·nosql·副本集