Umi 4 特性 04:build 阶段的构建提速

简介: Umi 4 特性 04:build 阶段的构建提速

🙋🏻‍♀️编者按:本文是蚂蚁集团前端工程师云谦关于 Umi 4 新特性系列分享的第四篇 - build 阶段的构建提速,欢迎享用~


第一篇👉🏻 Umi 4 特性 01:MFSU V3,比 Vite 还要快

第二篇👉🏻 Umi 4 特性 02:React Router 6 和新路由

第三篇👉🏻 Umi 4 特性 03:默认最快的请求


构建提速不只是 dev 阶段的 MFSU,还要考虑流程上 build 阶段的构建。build 阶段的构建相比 dev 阶段,会做很多额外的事,比如 js 压缩和 css 压缩、tree-shaking、code-splitting,同时对于依赖编译和缓存的利用方式也会不同。所以优化手段也会大不同。

esbuild


虽然构建提速没有银弹,但 esbuild 是这个时期的大杀器。


JS 压缩之前默认是 terser,Umi 4 之后默认是 esbuild。原因在《彻底告别编译 OOM,用 esbuild 做压缩器》有过介绍,除了快,还可彻底解压缩导致的 OOM 问题,缺点是相比 terser 尺寸会增加 10%。同时压缩方式还支持 terser、uglifyJs、swc,支持不同场景,比如针对不支持 es6 的场景,选 uglifyJs 可以在遇到高级语法时主动抛错。


export default {  jsMinifier: 'uglifyJs',  jsMinifierOptions: {},}


CSS 压缩之前默认是 cssnano,Umi 4 之后默认也是 esbuild。相比 cssnano,用 esbuild 压缩 CSS 速度提升 6 倍,而尺寸仅增加约 1%。同时也可通过配置切换回 cssnano,以及尝试我们试验性支持的 parcelCSS。

export default {  cssMinifier: 'parcelCSS',  cssMinifierOptions: {},}


esbuild 不仅用于压缩,还被用到 JS/TS 文件实时编译、import/export 分析、测试等环节。JS/TS 文件实时编译是为了让配置、MOCK 等文件支持 TypeScript 语法,所以会通过 require hook 的方式,在遇到 .ts 文件时自动用 esbuild 编译;import / export 分析通常用 es-module-lexer 分析,但由于他不支持 jsx,所以会用 esbuild 先编译到 esm 格式再给 es-module-lexer 使用Umi 4的测试默认用 esbuild 作为 js transformer,相比 ts-jest 快非常多,支持通过配置切换到 swc 或 ts-jest。


依赖编译


通常一个包含 600 文件的项目,会有 6000 文件的依赖。这也是为啥依赖编译速度很大程度上决定了项目构建速度。webpack 的依赖编译是个绕不开的点,因为就算我们什么都不配,webpack 也会通过 ast 的方式分析 import/export 等信息。


Umi 4 删除了 nodeModulesTransform,不会再做 node_modules 的全量 babel 编译,开发者需要手动找出使用了高级语法的依赖,手动配置。之前开启的项目通常是出于支持 es5 的考虑,而全量开启是比较偷懒的做法,但带来的问题是后续持续的构建时间消耗。


externals 是绕过 webpack 依赖编译的好办法,所以之前 yuyan 有推出 bmwAutoExternals 配置,但缺点是本地无法验证。dev 跑完没问题而流程上 build 完出问题的场景,一线开发者完全无法定位问题。Umi 4 会解这个问题,让本地也可做 bmwAutoExternals 的验证。


Umi 4 默认 webpack 5,而 webpack 5 是具备物理缓存功能的,这是相比 Vite 等其他工具非常大的优势,流程上也值得好好利用。Smallfish 之前就接入了基于迭代的构建物理缓存功能,Umi 4 也会跟上,在流程上做缓存的校验、下载和上传,让流程 build 进一步提速。注:这个 Remote Caching 的机制之后还会用到 MFSU 上,让依赖缓存的 invalidate 更精确。


参考:
https://zhuanlan.zhihu.com/p/139219361  

彻底告别编译 OOM,用 esbuild 做压缩器
https://github.com/vitejs/vite/pull/4371  

Vite 使用 esbuild 压缩 CSS 的 PR


相关文章
|
前端开发 开发者
Umi 4 特性 02:React Router 6 和新路由
Umi 4 特性 02:React Router 6 和新路由
1393 0
webpack优化篇(四十):速度分析:使用 speed-measure-webpack-plugin
webpack优化篇(四十):速度分析:使用 speed-measure-webpack-plugin
2161 0
webpack优化篇(四十):速度分析:使用 speed-measure-webpack-plugin
|
资源调度 前端开发 算法
前端依赖版本重写指南
感谢神奇的 Semver 动态规则,npm 社区经常会发生依赖包更新后引入破坏变更的情况(应用没有使用依赖锁的话),而应用开发者就要在自己的依赖声明里先临时绕过,避免安装到有问题的版本,如果是一级依赖,只需要改 package.json 的声明就可以了,但如果是子依赖,就需要进行版本重写(overrides/resolution)了。本文是一篇针对版本重写功能的指南性文章,当你遇到如下的问题时,就可以按照对应的依赖重写语法,解决这些依赖问题了。
7403 1
前端依赖版本重写指南
|
缓存 移动开发 Rust
前端构建工具 Mako 开源了
Hi,我是 sorrycc,Mako 的主要负责人之一,也是 Umi、Dva、Father 等库的作者。 很开心,Mako 终于开源了! Github 地址:https://github.com/umijs/mako/ 今天和大家正式介绍下他。
568 3
|
11月前
|
Web App开发 SQL 前端开发
前端页面加载性能指标之LCP
本文介绍了 Largest Contentful Paint (LCP),一种衡量网页加载性能的指标,专注于视口内最大图片或文本块的完全渲染时间,旨在提升用户对主要内容加载速度的感知。文章还探讨了LCP的测量方法和优化策略,如图像优化、懒加载等,以帮助改善网页性能。
984 5
|
前端开发
React页面跳转取消上一个页面的所有请求
React页面跳转时取消上一个页面的所有axios请求,通过axios拦截器设置cancelToken,并在页面跳转时调用cancel函数取消未完成的请求。
285 2
|
前端开发 UED 开发者
React.lazy()与Suspense:实现按需加载的动态组件——深入理解代码分割、提升首屏速度和优化用户体验的关键技术
【8月更文挑战第31天】在现代Web应用中,性能优化至关重要,特别是减少首屏加载时间和提升用户交互体验。React.lazy()和Suspense组件提供了一种优雅的解决方案,允许按需加载组件,仅在需要渲染时加载相应代码块,从而加快页面展示速度。Suspense组件在组件加载期间显示备选内容,确保了平滑的加载过渡。
392 0
|
编译器 Go 开发者
详尽解析:Golang 中的常量及其使用
【8月更文挑战第31天】
319 0
|
缓存 前端开发 开发者
探索前端开发新利器:MFSU
探索前端开发新利器:MFSU
444 0
|
前端开发 JavaScript API
ahooks 3.0 来了!高质量可靠的 React Hooks 库
ahooks 3.0 来了!高质量可靠的 React Hooks 库
1227 0