本节内容派生于以下链接指向的内容 ,并遵守 CC BY 4.0 许可证的规定。
以下内容如果没有特殊声明,可以认为都是基于原内容的修改和删减后的结果。
NormalModuleReplacementPlugin
可以帮你把 resourceRegExp
匹配的 import
/require
等模块请求(后面简称 请求 或 request)替换为 newResource
。
如果 newResource
是相对路径,则会相对于先前的资源进行解析。
如果 newResource
是一个函数,rspack 会传入请求数据,你应该在该函数中修改请求数据,比如 resource.request = resource.request + '.ibm'
。
这对于需要根据不同的情况使用不同的模块时非常有用。
请注意,resourceRegExp
在 beforeResolve
阶段跟 request
做匹配,在 afterResolve
阶段跟 resource
做匹配。前者是你在代码里写的请求字符串,后者是解析后的真实完整路径。
此外,请注意,在使用 Windows 时,你必须适应不同的路径分隔符。例如,/src\/environments\/environment\.ts/
在 Windows 上无法工作,相应的,你应该使用 /src[\\/]environments[\\/]environment\.ts/
。
以“为生产构建使用特定的模块”这个目标为例。
假设你有一个用于开发的配置文件 some/path/config.development.js
和一个专门用于生产的版本 some/path/config.production.js
。
可以在生产构建时这样配置该插件:
根据指定的环境条件构建。
假设你希望为不同的构建目标使用不同的配置:
创建两个配置文件:
然后根据插件配置中使用的 APP_TARGET
来 import
这个文件:
现在,根据你的构建目标,将导入相应的配置: