Rspack provides two solutions to support Preact:
Rspack leverages SWC transformer for JSX/TSX.
Add builtin:swc-loader loader to support jsx and tsx:
export default {
module: {
rules: [
{
test: /\.jsx$/,
use: {
loader: 'builtin:swc-loader',
options: {
jsc: {
parser: {
syntax: 'ecmascript',
jsx: true,
},
},
},
},
type: 'javascript/auto',
},
{
test: /\.tsx$/,
use: {
loader: 'builtin:swc-loader',
options: {
jsc: {
parser: {
syntax: 'typescript',
tsx: true,
},
},
},
},
type: 'javascript/auto',
},
],
},
};Refer to Builtin swc-loader for detailed configurations.
Refer to examples/preact for the full example.
To enable Preact Refresh, the following steps are required:
@rspack/plugin-preact-refresh plugin to inject runtime codeFirst you need to install the dependencies:
npm add @rspack/plugin-preact-refresh @prefresh/core @prefresh/utils -DThe enabling of the Preact Refresh is divided into two parts: code injection and code transformation
@prefresh/core and @prefresh/utils, which has been integrated in the @rspack/plugin-preact-refresh pluginbuiltin:swc-loader or swc-loader
jsc.transform.react.refresh to support common react transformation@swc/plugin-prefresh into jsc.experimental.plugins to support the specific transformation of preactbabel-loader and add official babel plugin of prefresh.
In versions below 1.0.0, Rspack did not support preact refresh with swc-loader.
builtin:swc-loader and enable preact specific transformation with rspackExperiments.preact: {}import PreactRefreshPlugin from '@rspack/plugin-preact-refresh';
const isDev = process.env.NODE_ENV === 'development';
export default {
// ...
mode: isDev ? 'development' : 'production',
module: {
rules: [
{
test: /\.jsx$/,
use: {
loader: 'builtin:swc-loader',
options: {
jsc: {
experimental: {
plugins: [
[
'@swc/plugin-prefresh', // enable prefresh specific transformation
{
library: ['preact-like-framework'], // the customizable preact name, default is `["preact", "preact/compat", "react"]`
},
],
],
},
parser: {
syntax: 'ecmascript',
jsx: true,
},
transform: {
react: {
development: isDev,
refresh: isDev, // enable common react transformation
},
},
},
},
},
},
],
},
plugins: [
isDev && new PreactRefreshPlugin(),
isDev && new rspack.HotModuleReplacementPlugin(),
],
};Refer to examples/preact-refresh for the full example.