Keep your source code clean, add magic coments to your dynamic import()
statements at build time.
NOTE: This loader ignores dynamic imports that already include comments of any kind.
Magic comments supported:
Usage
First npm install magic-comments-loader
.
Try not to have dynamic import()
statements behind comments. It is better to remove unused code in production.
If you must, e.g. your comment is referencing usage of dynamic imports, then these styles are ok:
If you must have a multiline comment then this style is ok (only one import()
per comment line preceded by an asterisk):
This module uses a RegExp not a parser. If you would like to add better support for ignoring import()
behind multiline comments please open a pull request. See some more examples on regexr.
Configuration
Add this inside your webpack.config.js
.
Without options
Adds webpackChunkName
to all dynamic imports (same as webpackChunkName: true
when using options).
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: ['magic-comments-loader']
}
]
}
With options
The loader options
is an object with keys corresponding to the names of supported magic comments. The following comments have a default behavior and do not require configuration beyond specifying where they should be applied (globally, or to certain files).
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'magic-comments-loader',
options: {
webpackChunkName: true,
webpackMode: 'lazy',
webpackIgnore: 'src/ignore/**/*.js',
webpackPrefetch: 'src/prefetch/**/*.js'
webpackPreload: [
'src/preload/**/*.js',
'!src/preload/skip/**/*.js'
]
}
}
}
]
}
With config
options
For more control, all comments support a configuration object with two supported keys, config
and overrides
. The config
key is an object used to specifiy comment options. The overrides
key is defined below.
All comments support a config.active
key: Boolean
| (modulePath, importPath) => Boolean
. This is used to enable or disable the comment.
Here is an example of using config
to customize comment behavior:
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'magic-comments-loader',
options: {
webpackChunkName: {
config: {
basename: true
}
},
webpackMode: {
config: {
mode: 'lazy-once'
}
},
webpackIgnore: {
config: {
active: false
}
}
}
}
}
]
}
Overrides
You can also override the configuration passed in the config
key by using overrides
. It is an array of objects that look like:
overrides: [
{
files: ['src/**/*.js'],
config: {
active: true,
mode: (modulePath, importPath) => {
if (/eager/.test(importPath)) {
return 'eager'
}
}
}
}
]
Here's a more complete example using config
and overrides
to customize how comments are applied:
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'magic-comments-loader',
options: {
verbose: true,
webpackChunkName: {
config: {
basename: false
},
overrides: [
{
files: 'src/unique/**/*.js',
config: {
basename: true
}
},
{
files: 'src/off/**/*.js',
config: {
active: false
}
}
]
},
webpackPrefetch: [
'src/prefetch/**/*.js',
'!src/prefetch/skip/**/*.js'
],
webpackMode: {
config: {
mode: 'lazy'
},
overrides: [
{
files: 'src/noMode/**/*.js',
config: {
active: false
}
},
{
files: [
'src/**/*.js',
'!src/weak/**/*.js'
],
config: {
mode: 'eager'
}
}
]
}
}
}
}
]
}
With loader options configured like
{
loader: 'magic-comments-loader',
options: {
webpackChunkName: true,
webpackPrefetch: 'src/some/module.js',
webpackMode: 'eager'
}
}
an import statement inside src/some/module.js
like
const dynamicModule = await import('./path/to/module.js')
becomes
const dynamicModule = await import( './path/to/module.js')
Options
These are the options that can be configured under the loader options
. When using comments with a config
key, you may also specify overrides
.
verbose
: Boolean. Prints console statements of the module filepath and updated import()
during the webpack build. Useful for debugging your custom configurations.match
: String(module|import)
. Sets how globs are matched, either the module file path or the import()
path. Defaults to 'module'
.webpackChunkName
true
: Adds webpackChunkName
comments to all dynamic imports. This is the default.false
: Disables adding the webpackChunkName
comment globally.['/src/**/*.js']
: Adds the comment when the glob(s) match a path from a match
path.Function
: (modulePath, importPath) => String(<chunk name>)
. Returning false
does not add the comment.config.active
: Boolean | (modulePath, importPath) => Boolean
. Returning false
does not add the comment.config.basename
: Boolean. Use only the basename from the import path as the chunk name. Relative imports may result in name collisions. Use in areas where you know the basenames are unique.
webpackPreload
true
: Adds webpackPreload
comments to all dynamic imports.false
: Disables adding the webpackPreload
comment globally. This is the default.['/src/**/*.js']
: Adds the comment with a value of true
when the glob(s) match a path from a match
path.Function
: (modulePath, importPath) => Boolean
. Returning false
does not add the comment.config.active
: Boolean | (modulePath, importPath) => Boolean
. Returning false
does not add the comment.
webpackPrefetch
true
: Adds webpackPrefetch
comments to all dynamic imports.false
: Disables adding the webpackPrefetch
comment globally. This is the default.['/src/**/*.js']
: Adds the comment with a value of true
when the glob(s) match a path from a match
path.Function
: (modulePath, importPath) => Boolean
. Returning false
does not add the comment.config.active
: Boolean | (modulePath, importPath) => Boolean
. Returning false
does not add the comment.
webpackIgnore
true
: Adds webpackIgnore
comments to all dynamic imports. You don't want to do this.false
: Disables adding the webpackIgnore
comment globally. This is the default.['/src/**/*.js']
: Adds the comment with a value of true
when the glob(s) match a path from a match
path.Function
: (modulePath, importPath) => Boolean
. Returning false
does not add the comment.config.active
: Boolean | (modulePath, importPath) => Boolean
. Returning false
does not add the comment.
webpackMode
true
: Adds webpackMode
comments to all dynamic imports using lazy
.false
: Disables adding the comment globally. This is the default.String(lazy|lazy-once|eager|weak)
: Adds the comment to all dynamic imports using the provided value.Function
: (modulePath, importPath) => String(lazy|lazy-once|eager|weak)
. Return falsy value to skip.config.active
: Boolean | (modulePath, importPath) => Boolean
. Returning false
does not add the comment.config.mode
: String(lazy|lazy-once|eager|weak)
| (modulePath, importPath) => String(lazy|lazy-once|eager|weak)
. Return falsy value to skip.
webpackExports
Function
: (modulePath, importPath) => [String(<module names|default>)]
. Return falsy value to skip.config.active
: Boolean | (modulePath, importPath) => Boolean
. Returning false
does not add the comment.config.exports
: (modulePath, importPath) => [String(<module names|default>)]
. Return falsy value to skip.