Luk*_*kas 6 webpack webpack-plugin extract-text-plugin
我正在编写一个 Webpack 插件,该插件应该用 Webpack 生成的 CSS 文件列表替换部分 JS 代码。对这个 JS 代码进行成像:
ReactWebComponent.create(<App />, 'react-web-component', { injectReactWebComponent: true });
Run Code Online (Sandbox Code Playgroud)
我想更换injectReactWebComponent: true零件
injectReactWebComponent: '<link href="static/css/main.cacbacc7.css" rel="stylesheet">'
Run Code Online (Sandbox Code Playgroud)
而那个链接标签是一个由 Webpack 生成的文件。
我的(某种工作)代码如下:
ReactWebComponent.prototype.apply = function(compiler) {
compiler.plugin('emit', function(compilation, callback) {
const cssFiles = Object.keys(compilation.assets)
.filter(fileName => /\.css$/.test(fileName));
const jsFiles = Object.keys(compilation.assets)
.filter(fileName => /\.js$/.test(fileName));
const cssLinkTagsAsString = cssFiles
.map(fileName => `<link href="${fileName}" rel="stylesheet">`)
.join('');
jsFiles.forEach(fileName => {
compilation.assets[fileName].children.forEach(child => {
if (child._value) {
child._value = child._value.replace(/injectReactWebComponent\s*:\s*true/g, `injectReactWebComponent: \'${cssLinkTagsAsString}\'`);
}
});
});
callback();
});
};
module.exports = ReactWebComponent;
Run Code Online (Sandbox Code Playgroud)
看到我做的那一行
child._value = child._value.replace(...)
Run Code Online (Sandbox Code Playgroud)
我直言不讳地重写了来源。
但这对我来说似乎不合适。我正在转换的代码似乎已经生成,不应再转换。我也很确定我正在用这个破坏源映射。
所以我想知道,实现我正在做的事情的合适方法是什么?
我猜测转换部分我应该使用 a loader,但是加载程序不知道生成的文件名,或者他们知道吗?
任何帮助,将不胜感激!
看起来这种事情很简单,可以由加载器处理,其中有多个(有些比其他更好):
https://www.npmjs.com/package/string-replace-loader
https://www.npmjs.com/package/regexp-replace-loader
https://www.npmjs.com/package/replace-loader
如果您想制作自己的插件来执行此操作(我刚刚经历了这个过程,做了一些比正则表达式替换更复杂的事情),我基本上可以从这三个页面将我的解决方案拼凑在一起:
https://github.com/webpack/webpack/blob/master/lib/BannerPlugin.js
https://webpack.js.org/api/plugins/compilation/#optimize-chunk-assets-chunks-chunk-async
https://github.com/webpack/webpack-sources
| 归档时间: |
|
| 查看次数: |
6103 次 |
| 最近记录: |