source.include
用于指定额外需要编译的 JavaScript 文件。
为了避免二次编译,默认情况下,Rsbuild 只会编译当前目录下的 JavaScript 文件,以及所有目录下的 TypeScript 和 JSX 文件,不会编译 node_modules 下的 JavaScript 文件。
通过 source.include
配置项,可以指定需要 Rsbuild 额外进行编译的目录或模块。source.include
的用法与 Rspack 中的 Rule.include 一致,支持传入字符串、正则表达式来匹配模块的路径。
比如:
比较典型的使用场景是编译 node_modules 下的 npm 包,因为某些第三方依赖存在 ESNext 的语法,这可能导致在低版本浏览器上无法运行,你可以通过该选项指定需要编译的依赖,从而解决此类问题。
如果你不确定 node_modules 中的哪些第三方依赖存在 ESNext 的语法,可以使用 @rsbuild/plugin-check-syntax 进行检查,插件可以帮助你找到存在 ESNext 语法的模块。
以 query-string
为例,你可以做如下的配置:
上述两种方法分别通过 "路径前缀" 和 "正则表达式" 来匹配文件的绝对路径,值得留意的是,项目中所有被引用的模块都会经过匹配,因此你不能使用过于松散的值进行匹配,避免造成编译性能问题或编译异常。
在上述正则表达式的例子中,我们使用 [\\/]
来匹配路径分隔符,这是因为不同的操作系统使用了不同的路径分隔符,使用 [\\/]
可以保证 macOS 和 Windows 的路径都被匹配到。
当你通过 source.include
编译一个 npm 包时,Rsbuild 默认只会编译匹配到的模块,不会编译对应模块的子依赖。
以 query-string
为例,它依赖的 decode-uri-component
包中同样存在 ESNext 代码,因此你需要将 decode-uri-component
也加入到 source.include
中:
在 Monorepo 中进行开发时,如果需要引用 Monorepo 中其他库的 JavaScript 代码,也可以直接在 source.include
进行配置:
如果你匹配的模块是通过 symlink 链接到当前项目中的,那么需要匹配这个模块的真实路径,而不是 symlink 后的路径。
比如,你将 Monorepo 中的 packages/foo
路径 symlink 到当前项目的 node_modules/foo
路径下,则需要去匹配 packages/foo
路径,而不是 node_modules/foo
路径。
通常来说,source.include
不应该用于编译整个 node_modules
目录,比如下面的写法是不推荐的:
这是因为 node_modules
中的大部分 npm 包发布的已经是编译后的产物,通常没必要经过二次编译。如果你对整个 node_modules
进行编译,会使编译时间增加,并且个别的 npm 包可能会产生不可预期的错误,比如 core-js
被编译后会出现运行时异常。
如果你可以接受编译时间的增加,可以通过下面的配置来编译所有 JavaScript 文件,但是需要排除 core-js
: