随着研发代码的增多, 工程日益复杂,代码复用和版本管理显得格外的繁琐,版本升级没有日志,相互依赖的包需要手动管理版本,以往的组件库独立开发的方式并没有很好的区分组件和组件之间的关系,往往只需要一种类型的组件,例如图表,但还是不得不安装一整个组件库,并没有很好的对组件进行区分,如哪些是图表组件,哪些是功能组件,哪些是业务组件等,造成组件库越来越大,编译打包效率降低,每次一个小改动就不得不直接发布一整个包预览效果,且无法支持本地调试等以下相关痛点。
- 组件耦合严重,组件代码量大
- 业务开发分工不明确,业务开发人员要关心非业务的代码
- 编译慢,效率低
- 无法对应用做增量更新
- 相关包基础依赖可能会重复打包,如: lodash,moment...
- 管理、调试、追踪 bug 困难
- 不同项目之间 node、node-sass、webpack 等基础依赖版本不统一,切换增加心智负担。
- 不同项目可能存在技术栈不统一,如:状态管理,less,sass
- 分支管理混乱
- 多包多项目之间依赖关系复杂
- 第三方依赖库版本可能不一致
- 占用总空间大
- 不利于团队协作
- 无法针对主应用统一跑测试用例,发布时很难避免一些基本的错误发生
- 需要频繁切换项目
- 搭建独立的文档系统和其他子应用时,相关依赖又要单独管理,又有上述的症状
- 无法跨部门共享基建产物资产元数据
针对上述问题我们引入了 Monorepo 的概念,把以往的单一组件库拆分为职责更细化的包,架构更清晰,解耦,子应用隔离,并且做了严格的 CR,CI 机制(暂无 CD)、自动化构建、测试流水线、代码问题校验,工程化的最终目的是让业务开发可以 100% 聚焦在业务逻辑上精读《Monorepo 的优势》, 现代化前端应用为什么越来越离不开 Monorepo
- @vis/utils 工具库,常用的工具函数或者 hooks 等,如 transformData,uuid,timeFormat....
- @vis/test 这里你可以做任意操作,如测试 CI 自动化脚本,功能相关的东西,总之就是随便玩
- @vis/charts 基于antv下大屏画布或者仪表板图表库二次封装后的组件,如:条形进度图,词云图,饼图等...
- @vis/components 存放功能性组件,更偏向系统功能,如右键菜单,拖拽改变布局宽高...
- @vis/common 其他相关且通用性强的东西
- @vis/decorator 装饰器,包含 svg 渲染的所有动画和装饰,相比图片或者动图,可随意放大缩小,且轻量级。
防止后期主应用过大增加 dev 和编译负担,我们把以往的主应用下不相关的部分拆分成了独立的项目,然后使用微前端和模块联邦来对接子应用(代码共享和状态管理),这样整个应用能 hold 住未来不断扩张的业务线和人员开发,也不会出现在不同应用中组件库代码被重复打包。我们特意将组件库代码从主应用中抽离出来,每个独立的子应用共享主应用内导出的 exposes 文件夹下的模块。
- [/project/dataModel]数据模型项目代码
- [/project/template]子应用模版
我们所有的包管理都强制使用pnpm,在 monorepo 架构之上,pnpm 能极大发挥他的作用(设计初期就很好的考虑了当前复杂项目的痛点),相比 yarn 和 npm,pnpm 能节约磁盘空间并提升安装速度,切避免了关于深度嵌套包的一些意外情况,如果你还没有接触了解过 pnpm,可以看看相关文章, 而且当前已有众多前端团队和大部分主流开源项目抛弃 npm,yarn,开始接入 pnpm。
pnpm i
安装npm run dev
# 运行主项目npm run build
# 打包主项目npm run dev-project
# 运行项目下的子应用(visual, dashboard, dataModel, ....)npm run build-lib
# 懒加载打包(esm, cjs 格式)package 下所有库(保留文件的引用关系,可以查看对应包下面的 lib 和 es 文件夹),能解耦主应用代码,避免重复打包npm run build-dist
# 打包生产环境下 package 下所有库(压缩,生成单文件),适用于给其他团队项目中使用,仅忽略 antd,proComponents,moment 库npm run build-selectPkg
# 手动选择打包,防止后期包太多的情况全部打包消耗过多资源和时间npm run docs
# 运行项目文档, 包含组件库文档和项目说明等npm run test
# 跑测试用例
npm run release
提供界面交互可视化自动发包npm run release:only
手动修改版本号后发包 查看更多
为了很好的区分应用和对应的路由,我们建议所有子应用使用 hash 路由开发,这样就能统一路由风格,增加路由的可读性,且能减少很多不必要的 nginx 配置 😊
http://10.28.184.132:8088/dash/#/list?type=dashboard
地址拆分解析:
http://10.28.184.132:8088
- 主机地址/dash
- 路由的 history 用来区分子应用/#/list
- hash 路由参数为子应用自己的路由?type=dashboard
- 传参
- changeSets :发包工具
- dumi:文档工具
- father-builder: 库打包工具
- testing-library: react 测试库
- husky 代码提交规范工具
- jest:自动化测试框架
- react chorme debug: react 调试 & 性能分析
- vscode monorepo workspace: monorepo 工程 vscode 插件,一键整理工程代码
Edge | last 2 versions | last 2 versions | last 2 versions | last 2 versions |