Skip to content

Commit

Permalink
docs: ContextReplacementPlugin
Browse files Browse the repository at this point in the history
  • Loading branch information
SyMind committed Sep 20, 2024
1 parent b75cce4 commit a682188
Show file tree
Hide file tree
Showing 4 changed files with 120 additions and 2 deletions.
3 changes: 2 additions & 1 deletion website/docs/en/plugins/webpack/_meta.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,5 +22,6 @@
"normal-module-replacement-plugin",
"javascript-modules-plugin",
"internal-plugins",
"no-emit-on-errors-plugin"
"no-emit-on-errors-plugin",
"context-replacement-plugin"
]
58 changes: 58 additions & 0 deletions website/docs/en/plugins/webpack/context-replacement-plugin.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import WebpackLicense from '@components/WebpackLicense';

<WebpackLicense from="https://webpack.js.org/plugins/context-replacement-plugin/" />

# ContextReplacementPlugin

`Context` refers to a `require` or dynamic `import()` with an expression such as `require('./locale/' + name + '.json')`.
When encountering such an expression, Rspack infers the directory (`'./locale/'`) and a regular expression (`/^.*\.json$/`).
Since the name is not known at compile time, Rspack includes every file as module in the bundle.

The `ContextReplacementPlugin` allows you to override the inferred information. There are various ways to configure the plugin:

## Options

- **Type:**

```ts
new rspack.ContextReplacementPlugin(
resourceRegExp: RegExp,
newContentResource?: string,
newContentRecursive?: boolean,
newContentRegExp?: RegExp
)
```

If the resource (directory) matches `resourceRegExp`, the plugin replaces the default resource, recursive flag or generated regular expression with `newContentResource`, `newContentRecursive` or `newContextRegExp` respectively.
If `newContentResource` is relative, it is resolved relative to the previous resource.

## Examples

### Basic Use Case

```js
new rspack.ContextReplacementPlugin(/moment[/\\]locale$/, /de|fr|hu/);
```

The `moment/locale` context is restricted to files matching `/de|fr|hu/`. Thus only those locales are included (see [this issue](https://github.com/moment/moment/issues/2373) for more information).

### Other Options

The `newContentResource` and `newContentCreateContextMap` parameters are also available:

```ts
new rspack.ContextReplacementPlugin(
resourceRegExp: RegExp,
newContentResource: string,
newContentCreateContextMap: object // mapping runtime-request (userRequest) to compile-time-request (request)
);
```

These two parameters can be used together to redirect requests in a more targeted way. The `newContentCreateContextMap` allows you to map runtime requests to compile requests in the form of an object:

```js
new rspack.ContextReplacementPlugin(/selector/, './folder', {
'./request': './request',
'./other-request': './new-request',
});
```
3 changes: 2 additions & 1 deletion website/docs/zh/plugins/webpack/_meta.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,5 +22,6 @@
"normal-module-replacement-plugin",
"javascript-modules-plugin",
"internal-plugins",
"no-emit-on-errors-plugin"
"no-emit-on-errors-plugin",
"context-replacement-plugin"
]
58 changes: 58 additions & 0 deletions website/docs/zh/plugins/webpack/context-replacement-plugin.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import WebpackLicense from '@components/WebpackLicense';

<WebpackLicense from="https://webpack.js.org/plugins/context-replacement-plugin/" />

# ContextReplacementPlugin

`context` 是指带有表达式的 `require` 或动态 `import()`,例如 `require('./locale/' + name + '.json')`
遇到这种表达式时,Rspack 会推断出目录(`'./locale/'`)和一个正则表达式(`/^.*.json$/`)。
由于在编译时无法确定 `name`,Rspack 会将每个文件都作为模块打包。

`ContextReplacementPlugin` 允许你覆盖这些推断的信息。该插件可以通过多种方式进行配置:

## 选项

- **类型:**

```ts
new rspack.ContextReplacementPlugin(
resourceRegExp: RegExp,
newContentResource?: string,
newContentRecursive?: boolean,
newContentRegExp?: RegExp
)
```

如果目录匹配 `resourceRegExp`,插件会用 `newContentResource``newContentRecursive``newContextRegExp` 分别替换默认资源、递归标志或生成的正则表达式。
如果 `newContentResource` 是相对路径,则相对于前一个资源进行解析。

## 示例

### 基本使用

```js
new rspack.ContextReplacementPlugin(/moment[/\\]locale$/, /de|fr|hu/);
```

这个示例限制了 `moment/locale` 目录下的文件,仅打包匹配 `/de|fr|hu/` 的文件。因此,仅包含这些语言模块(在[这里](https://github.com/moment/moment/issues/2373)了解更多信息)。

### 其他选项

关于 `newContentResource``newContentCreateContextMap` 参数:

```ts
new rspack.ContextReplacementPlugin(
resourceRegExp: RegExp,
newContentResource: string,
newContentCreateContextMap: object // 映射运行时请求(userRequest)到编译时请求(request)
);
```

这两个参数可以一起使用,以更有针对性地重定向请求。`newContentCreateContextMap` 允许你以对象的形式映射运行时请求到编译时请求:

```js
new rspack.ContextReplacementPlugin(/selector/, './folder', {
'./request': './request',
'./other-request': './new-request',
});
```

0 comments on commit a682188

Please sign in to comment.