webpack插件给所有的:src文件目录增加前缀

1.webpack4的版本写法

javascript 复制代码
class AddPrefixPlugin {
  apply(compiler) {
    compiler.hooks.compilation.tap('AddPrefixPlugin', (compilation) => {
      HtmlWebpackPlugin.getHooks(compilation).beforeEmit.tapAsync(
        'AddPrefixPlugin',
        (data, cb) => {
          // 使用正则表达式替换所有包含 /static/file/ 的路径
          data.html = data.html.replace(/\/static\/file\//g, '/zhgdxmf/static/file/');
          cb(null, data);
        }
      );
    });
    compiler.hooks.emit.tapAsync('AddPrefixPlugin', (compilation, callback) => {
      // 遍历所有输出的资源文件,替换其中的 /static/file/ 路径
      Object.keys(compilation.assets).forEach((assetName) => {
        if (assetName.endsWith('.js') || assetName.endsWith('.html')) {
          let content = compilation.assets[assetName].source();
          content = content.replace(/\/static\/file\//g, '/zhgdxmf/static/file/');
          compilation.assets[assetName] = {
            source: () => content,
            size: () => content.length
          };
        }
      });
      callback();
    });
  }
}

module.exports = AddPrefixPlugin;

webpack 2 的版本

javascript 复制代码
function AddPrefixPlugin(options) {
  this.options = options || {};
}

AddPrefixPlugin.prototype.apply = function(compiler) {
  compiler.plugin('compilation', (compilation) => {
    compilation.plugin('html-webpack-plugin-before-html-processing', (htmlPluginData, callback) => {
      // 使用正则表达式替换所有包含 /static/file/ 的路径
      htmlPluginData.html = htmlPluginData.html.replace(/\/static\/file\//g, '/zhgdxmf/static/file/');
      callback(null, htmlPluginData);
    });

    compilation.plugin('optimize-assets', (assets, callback) => {
      // 遍历所有输出文件,替换其中的 /static/file/ 路径
      Object.keys(assets).forEach((assetName) => {
        if (assetName.endsWith('.js') || assetName.endsWith('.html')) {
          let content = assets[assetName].source();
          content = content.replace(/\/static\/file\//g, '/zhgdxmf/static/file/');
          assets[assetName] = {
            source: () => content,
            size: () => content.length
          };
        }
      });
      callback();
    });
  });
};

module.exports = AddPrefixPlugin;

使用


全程借助chatgpt完成,感慨能力之强大啊

相关推荐
rzl0211 分钟前
java web5(黑马)
java·开发语言·前端
Amy.Wang13 分钟前
前端如何实现电子签名
前端·javascript·html5
今天又在摸鱼15 分钟前
Vue3-组件化-Vue核心思想之一
前端·javascript·vue.js
蓝婷儿17 分钟前
每天一个前端小知识 Day 21 - 浏览器兼容性与 Polyfill 策略
前端
百锦再19 分钟前
Vue中对象赋值问题:对象引用被保留,仅部分属性被覆盖
前端·javascript·vue.js·vue·web·reactive·ref
jingling55524 分钟前
面试版-前端开发核心知识
开发语言·前端·javascript·vue.js·面试·前端框架
拾光拾趣录29 分钟前
CSS 深入解析:提升网页样式技巧与常见问题解决方案
前端·css
莫空000030 分钟前
深入理解JavaScript属性描述符:从数据属性到存取器属性
前端·面试
guojl30 分钟前
深度剖析Kafka读写机制
前端
FogLetter31 分钟前
图片懒加载:让网页飞起来的魔法技巧 ✨
前端·javascript·css