The content of this section is derived from the content of the following links and is subject to the CC BY 4.0 license.
The following contents can be assumed to be the result of modifications and deletions based on the original contents if not specifically stated.
Enable and try out some experimental features.
object
In minor releases, Rspack may make changes to the APIs of these experimental features and provide detailed explanations of these changes in the release notes. So if you are using experimental features, please pay attention to the minor release notes.
boolean
false
Support the new WebAssembly according to the updated specification, it makes a WebAssembly module an async module.
And it is enabled by default when experiments.futureDefaults is set to true
.
boolean
true
Once enabled, Rspack will output ECMAScript module syntax whenever possible. For instance, import()
to load chunks, ESM exports to expose chunk data, among others.
boolean
false
Once enabled, Rspack will enable native CSS support, and CSS related parser and generator options.
module.parser["css/auto"]
module.parser.css
module.parser["css/module"]
module.generator["css/auto"]
module.generator.css
module.generator["css/module"]
Basic example:
Use defaults of the next major Rspack and show warnings in any problematic places.
Enable support for Top-level await, Top-level await
can only be used in modules with ModuleType is javascript/esm
.
Enabled by default and can be disabled with this configuration:
boolean | LazyCompilationOptions
false
Enable lazy compilation, which can greatly improve the dev startup performance of multi-page applications (MPA) or large single-page applications (SPA). For example, if you have twenty entry points, only the accessed entry points will be built. Or if there are many import()
statements in the project, each module pointed to by import()
will only be built when it is actually accessed.
If set to true, lazy compilation will be applied by default to both entry modules and modules pointed to by import()
. You can decide whether it applies only to entries or only to import()
through a configuration object. The entries
option determines whether it applies to entries, while the import()
option determines whether it applies to import()
.
In addition, you can also configure a test
parameter for more fine-grained control over which modules are lazily compiled. The test
parameter can be a regular expression that matches only those modules that should be lazily compiled. It can also be a function where the input is of type 'Module' and returns a boolean value indicating whether it meets the criteria for lazy compilation logic.
The current lazy compilation aligns with the webpack implementation, and is still in the experimental stage. In some scenarios, lazy compilation might not work as expected, or the performance improvement may be insignificant.
number | ListenOptions
If you do not use Rspack's own dev server and instead use your own server as the dev server, you generally need to add another client modules in the entry configuration to enable capabilities such as HMR. It is best to exclude these client module from lazy compilation by configuring test
.
If not excluded and lazy compilation of entry is enabled, this client will not be compiled when accessing the page for the first time, so an additional refresh is needed to make it take effect.
For example:
boolean
false
Controls whether to enable the layer feature. Layers can add an identifier prefix to all modules in a subgraph starting from a module in the module graph, to distinguish them from modules in different layers. For example:
The layer
of the index.js
module is by default null
, and its identifier
is ./index.js
. If we set layer = 'client'
for it, its identifier
will become (client)/./index.js
. At this point, the index.js
modules in these two different layers will be treated as distinct modules, because their unique identifier
s are different. As a result, the final output will include the artifacts of both modules.
By default, a module's layer is null
, and it will inherit its parent module's layer. You can add a layer to an entry module using entryOptions.layer
, and you can add a layer to matched modules using module.rule[].layer
. Additionally, you can match based on the parent module's layer using module.rule[].issuerLayer
.
boolean | Incremental
false
, development mode is{ make: true, emitAssets: true }
Whether to enable incremental rebuild to speed up the rebuild speed. It is recommended to enable it only during development.
true
means enable incremental for all stages. false
means disable incremental for all stages. Incremental can also be enabled only for specified partial stages:
Currently, incremental for the make
and emitAssets
stages is enabled by default. This is also the default behavior since Rspack v1.0. As this feature further stabilizes, we will enable incremental for more stages by default.
This feature is experimental. You can check its relevant progress at rspack#8106. You can also report bugs and any related feedback here.
Type: object
Default: See options down below for details
Used to control whether to enable Rspack future default options, check out the details here.
Used to inject the currently used Rspack information into the generated asset:
version
: Used to specify the Rspack version, defaults to the version
field in @rspack/core/package.json
.bundler
: Used to specify the name of the packaging tool, defaults to rspack
.force
: Whether to force the injection of Rspack information, which will be added to chunk as a runtime module, and defaults to true
to force injection. An array can be used to select the items to be forced injected。The default injection can be disabled by setting force
to false
. Then injection will only occur when __rspack_version__
and __rspack_unique_id__
are detected in the code:
__rspack_version__
: Inject version information.__rspack_unique_id__
: Inject the unique ID of the bundler.Type: ExperimentCacheOptions
Default: production mode is false
, development mode is true
Control experimental caching behavior. This will only work if global cache is set to true
.
Configuring experiment.cache
to false
to disable cache, which is no different from configuring the global cache to false
.
Configuring experiment.cache
to true
or { "type": "memory" }
to enable memory cache.
Configuring experiment.cache
to { "type": "persistent" }
to enable persistent cache.
Type: string[]
Default: []
cache.buildDependencies
is an array of files containing build dependencies, Rspack will use the hash of each of these files to invalidate the persistent cache.
It's recommended to set cache.buildDependencies
: [__filename] in your rspack configuration to get the latest configuration.
Type: string
Default: ""
Cache versions, different versions of caches are isolated from each other.
In addition to buildDependencies and version configurations that affect persistent cache invalidation, Rspack also invalidates persistent cache when the following fields change.
Configure snapshot strategy. Snapshot is used to determine which files have been modified during shutdown. The following configurations are supported:
Type: (RegExp | string)[]
Default: []
An array of paths to immutable files, changes to these paths will be ignored during hot restart.
Type: (RegExp | string)[]
Default: [/\/node_modules\//]
An array of paths managed by the package manager. During hot start, it will determine whether to modify the path based on the version in package.json.
Type: (RegExp | string)[]
Default: []
Specifies an array of paths in snapshot.managedPaths
that are not managed by the package manager
Type: { type: 'filesystem', directory: string }
Default: { type: 'filesystem', directory: 'node_modules/.cache/rspack' }
Configure cache storage. Currently only file system storage is supported. The cache directory can be set through directory
. The default is node_modules/.cache/rspack
.