CC 4.0 协议
本节内容派生于以下链接指向的内容 ,并遵守 CC BY 4.0 许可证的规定。
以下内容如果没有特殊声明,可以认为都是基于原内容的修改和删减后的结果。
DefinePlugin
DefinePlugin 在编译时将代码中的变量替换为其他值或表达式。这对于允许开发构建和生产构建之间的不同行为非常有用。如果你在开发构建中执行日志记录,但在生产构建中则不执行,你可能会使用一个全局常量来决定是否进行日志记录。这正是 DefinePlugin 的用武之地,为开发和生产构建设置一成不变的规则。
选项
- 类型:
示例
基本使用
传入 DefinePlugin 的每个键都是一个标识符或多个标识符用 . 连接。
- 如果值是一个字符串,它将被用作代码片段。
- 如果值不是字符串,它会被转化为字符串(包括函数)。
- 如果值是一个对象,所有键都以相同的方式定义。
- 如果你在键前加上
typeof,它只在 typeof 调用中被定义。
这些值将被内联到代码中,允许在压缩阶段删除掉那些冗余的条件判断。
在为 process 定义值时,推荐使用 'process.env.NODE_ENV': JSON.stringify('production') 而不是 process: { env: { NODE_ENV: JSON.stringify('production') } }。使用后者会重写 process 对象,这可能会破坏对某些模块的兼容性,这些模块期望 process 对象上的其他值被定义。
请注意,由于插件直接执行文本替换,因此提供给它的值必须包含字符串内部的实际引号。通常,这是通过使用交替引号,如 '"production"',或使用 JSON.stringify('production') 来完成。
通过 Rspack,但不进行压缩后的结果为:
在压缩后的结果为:
特性标志
使用特性标志在生产/开发构建中启用/禁用功能。
服务 URL
在生产/开发构建中使用不同的服务 URL:
使用 JSON.stringify
当你希望注入的是字面量值,而不是代码片段时,应使用 JSON.stringify。
常见场景包括:
- 注入字符串常量,例如环境名、版本号、接口地址。
- 注入对象或数组,并在业务代码中直接读取其内容。
- 注入
process.env.*这类来自环境变量的字符串值。
这是因为 DefinePlugin 中的字符串会被直接当作代码插入,而不会自动补上引号。
上面的 MODE 会被当作标识符 production,而不是字符串 'production',通常会导致运行时错误。MODE_STRINGIFIED 则会被替换为合法的字符串字面量,是更安全的写法。
如果需要注入对象或数组,也建议使用 JSON.stringify:
这样生成的 APP_INFO 会是一个可直接使用的对象字面量。否则,像 APP_INFO: { ... } 这样的写法会被 DefinePlugin 当作嵌套定义配置递归处理,而不是按对象字面量注入到业务代码中。

