type CheckSyntax =
| boolean
| {
targets?: string[];
exclude?: RegExp | RegExp[];
ecmaVersion?: EcmaVersion;
};false用于分析构建产物中是否存在当前浏览器范围下不兼容的高级语法。如果存在,会将详细信息打印在终端。
你可以将 checkSyntax 设置为 true 来启用语法检测。
export default {
security: {
checkSyntax: true,
},
};当你开启 checkSyntax 后,Modern.js 会在生产环境构建时进行检测,当在构建产物中检测到不兼容的高级语法后,会将错误日志打印在终端,并退出当前构建流程。
错误日志的格式如下所示,包含代码来源文件、产物位置、错误原因、源代码等信息:
error [Syntax Checker] Find some syntax errors after production build:
Error 1
source: /node_modules/foo/index.js:1:0
output: /dist/static/js/main.3f7a4d7e.js:2:39400
reason: Unexpected token (1:178)
code:
9 |
10 | var b = 2;
11 |
> 12 | console.log(() => {
13 | return a + b;
14 | });
15 |目前语法检测是基于 AST parser 来实现的,每次检测时,只能找出文件中的第一个不兼容语法。如果一个文件中存在多个不兼容语法,你需要修复已发现的语法,并重新执行检测。 如果日志中没有显示对应的源码位置,可以尝试将 output.minify 设置为 false 后再重新构建。
当检测到语法错误后,你可以通过以下方式来处理:
source.include 配置来编译相应的模块。checkSyntax.exclude 配置排除要检查的文件。security.checkSyntax 底层基于 @rsbuild/plugin-check-syntax 实现,具体选项可参考 @rsbuild/plugin-check-syntax。