Rsbuild 0.5 发布

March 19, 2024

Rsbuild 0.5 是一个重要的里程碑,从该版本开始,Rsbuild 的绝大部分 API 已经达到稳定状态,我们预计在 2024 年 Q3 发布 Rsbuild v1.0。

主要变更:

  • ⚡️ 支持启用 Lightning CSS 以加速 CSS 编译。
  • 🌟 支持基于新的 JavaScript API 实现自定义 server。
  • 🍭 重构 SVGR 插件以支持更丰富的用法。
  • 📍 支持自定义压缩选项。

⚡️ 支持 Lightning CSS

Lightning CSS 是一个基于 Rust 编写的高性能 CSS 解析、转译和压缩工具。它支持将许多现代的 CSS 特性解析并转化为指定浏览器支持的语法,并提供更好的压缩比例。

Rsbuild 提供了 Lightning CSS 插件,用于按需开启 Lightning CSS 能力,并替代 Rsbuild 内置的 PostCSS、autoprefixer 和 SWC CSS minimizer。

只需要在 Rsbuild 配置中注册 Lightning CSS 插件,即可完成切换:

rsbuild.config.ts
import { pluginLightningcss } from '@rsbuild/plugin-lightningcss';

export default {
  plugins: [pluginLightningcss()],
};

在一个真实的大型 Web 应用中,我们接入了 Rsbuild Lightning CSS 插件,并使用 Rsdoctor 分析构建耗时的变化:

  • CSS 编译耗时由 8.4s 降低到 0.12s,提升 70 倍。
  • 整体构建耗时由 33.1s 降低到 25.4s,提升 30%。

🌟 支持自定义 Server

Rsbuild 现在支持将 dev server 替换为自定义的 server,并复用 Rsbuild 提供的页面预览、路由、模块热更新等功能。这将使得 Rsbuild 与其他 Node.js 框架结合使用变得更加容易。

比如基于 express 实现自定义 server:

import express from 'express';
import { createRsbuild } from '@rsbuild/core';

async function startCustomServer() {
  const app = express();
  const rsbuild = await createRsbuild();
  const { port, middlewares } = await rsbuild.createDevServer();

  app.use(middlewares);
  app.listen(port);
}

详情可参考 Rsbuild - createDevServer

🍭 重构 SVGR 插件

在 0.5.0 之前的版本中,SVGR 插件的默认用法与 create-react-app 保持一致,允许以混合导入的形式使用 SVG:

import logoUrl, { ReactComponent as Logo } from './logo.svg';

console.log(logoUrl); // -> string
console.log(Logo); // -> React component

但这种做法存在两个问题:

  1. 包体积增加:混合导入会导致单个 SVG 模块被编译为两种代码(即使部分导出没有被使用),这会增加产物的包体积。
  2. 编译速度下降:混合导入会产生额外的编译开销。即使代码中未使用到 ReactComponent 导出,SVG 文件仍然会被 SVGR 编译。而 SVGR 是基于 Babel 实现的,性能开销较大。

因此,我们重构了 @rsbuild/plugin-svgr 插件,支持通过 ?react query 来将 SVG 转换为 React 组件,这种用法能够解决以上问题,且更符合当前社区的最佳实践。

import logoUrl from './logo.svg';
import Logo from './logo.svg?react';

console.log(logoUrl); // -> string
console.log(Logo); // -> React component

SVGR 插件现在支持在多种 SVGR 用法之间切换,如果项目需要使用之前的混合导入用法,可以手动开启 mixedImport 选项:

pluginSvgr({
  mixedImport: true,
});

📍 自定义压缩选项

output.disableMinimize 选项已经被重命名为 output.minify,并允许自定义 JS 和 HTML 的压缩选项。

rsbuild.config.ts
export default {
  output: {
    minify: {
      jsOptions: {
        minimizerOptions: {
          mangle: false,
        },
      },
    },
  },
};

使用 output.disableMinimize 的项目可以参考以下示例:

export default {
  output: {
-    disableMinimize: true,
+    minify: false,
  },
};

详见 "allow customize minify options"


更多内容请参考: