Solid 插件
Solid 插件提供了对 Solid 的支持,插件内部集成了 babel-preset-solid。
快速开始
安装插件
你可以通过如下的命令安装插件:
注册插件
你可以在 rsbuild.config.ts 文件中注册插件:
注册插件后,你可以直接进行 Solid 开发。
由于 Solid 的 JSX 依赖 Babel 进行编译,因此你需要额外添加 Babel 插件。
Babel 编译会产生额外的编译开销,在上述例子中,我们通过 include 来匹配 .jsx 和 .tsx 文件,从而减少 Babel 带来的性能开销。
解析行为
Solid 插件会将 solid 添加到 Rsbuild 的 resolve.conditionNames 中,使 package exports 可以解析到 Solid 专属的入口。
在开发模式下,插件还会添加 development,用于解析 Solid 的开发环境运行时。你可以通过 dev: false 关闭该行为。
如果你配置了 resolve.conditionNames,插件会保留已有配置,并在前面添加这些 Solid 条件。
选项
如果你需要自定义 Solid 的编译行为,可以使用以下配置项。
dev
是否在开发模式下解析 Solid 的开发环境运行时。设置为 false 可以禁用 development condition,设置为 true 可以在生产模式下强制启用 development condition。
- 类型:
boolean - 默认值: 开发模式下为
true,生产模式下为false - 示例:
refresh.disabled
是否在开发模式下禁用 Solid Refresh HMR。该选项只控制 Solid Refresh 注入,不会禁用 Rsbuild HMR。
- 类型:
boolean - 默认值:
false - 示例:
ssr
是否生成 Solid SSR 输出。启用后,插件会为 Node.js target 设置 generate: 'ssr' 和 hydratable: true,为其他 target 设置 generate: 'dom' 和 hydratable: true。
solid 中的配置会覆盖这些默认值。
- 类型:
boolean - 默认值:
false - 示例:
solid
传递给 babel-preset-solid 的选项,请查阅 babel-preset-solid 文档 来了解具体用法。
- 类型:
SolidPresetOptions - 默认值:
{} - 示例:
solidPresetOptions是solid的废弃别名,请使用solid代替。如果两个选项同时设置,则solid优先生效。

