当前位置: 首页 > news >正文

webpack自定义插件 ChangeScriptSrcPlugin

插件文件

class ChangeScriptSrcPlugin {apply(compiler) {const pluginName = "ChangeScriptSrcPlugin";compiler.hooks.compilation.tap(pluginName, (compilation, callback) => {compilation.hooks.htmlWebpackPluginAlterAssetTags.tapAsync(pluginName,(htmlPluginData, callback) => {htmlPluginData.body.filter(item => {const { attributes } = item;return (attributes.src.includes("main") &&attributes.type === "text/javascript");}).forEach(ele => {ele.attributes.src = ele.attributes.src.replace("http://localhost:3000/","http://localhost:3000/");});callback(null, htmlPluginData);});});}
}module.exports = ChangeScriptSrcPlugin;

配置文件 webpack.config.js

// webpack.config.js
var ChangeScriptSrcPlugin = require('ChangeScriptSrcPlugin.js');module.exports = {// ... 这里是其他配置 ...plugins: [new ChangeScriptSrcPlugin()],
};

一、compiler 和 compilation的区别 和 作用

/** 1、compiler(编译器)  和 compilation(编译)的区别 和 作用* 打包是被细分为很多个子进度的。* compiler 是 webpack 打包过程的一个编译器,这个对象上有打包过程中的很多钩子函数。* compilation 是 compiler上的一个子进度,也包含了许多钩子函数。htmlWebpackPluginAlterAssetTags就是其中一个** 在编译的每个阶段中,任何插件都拥有对 compiler 对象的完全访问能力,* 并且在合适的时机,还可以访问当前的 compilation 对象。** compiler * 1. 包含整个构建流程的全部钩子,通过它可以把控整个 webpack 构建周期。* 2. 在运行期间 compiler 会根据 webpack 不同阶段触发的各种事件钩子,执行插件附加/绑定在 hook 上的函数。* 3. 只是负责维持生命周期运行的功能,所有的加载、打包和写入工作,都被委托到注册过的插件上了。* 4. 对象代表的是构建过程中不变的 webpack 环境,整个 webpack 从启动到关闭的生命周期。针对的是webpack。* * compilation * 1. 只代表一次新的编译,只要项目文件有改动,compilation 就会被重新创建。针对的是随时可变的项目文件。* 2. 负责:构建 module 和 chunk,并利用插件优化构建过程,同时把本次打包编译的内容全存到内存里作者:AizawaSayo
链接:https://www.jianshu.com/p/fb3a8182838c
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。* */

2. htmlWebpackPluginAlterAssetTags 方法

/** 2、htmlWebpackPluginAlterAssetTags*  上边这个钩子函数,必须得让webpack使用  📚📚htmlWebpackPlugin📚 才能访问*  HtmlWebpackPlugin 简化了 HTML 文件的创建,以便为你的 webpack 包提供服务。这对于那些文件名中包含哈希值,并且哈希值会随着每次编译而改变的 webpack 包特别有用。* */

3. tabTable

/** 3、Tabable  类的方法* 参考 https://zhuanlan.zhihu.com/p/367931462 理解Tapable* Tabable * Tapable 使用时通常需要经历如下步骤:*  1. 创建钩子实例*  2. 调用【订阅接口】,【注册】回调,包括:tap、tapAsync、tapPromise*  3. 调用【发布接口】,【触发】回调,包括:call、callAsync、promise(之前我一直以为 发布订阅 是 先发布 再订阅,注册是在发布这一步做的。) ** 同步 hook 只能使用 tap 方法;而异步 hook 除了 tapAsync 和 tapPromise 这些异步方法,也支持用 tap 方法让 hook 以同步方式运行。* */

在这里插入图片描述

http://www.lryc.cn/news/464815.html

相关文章:

  • win11 笔记本指纹驱动正常就是使用不了
  • 表的约束
  • jmeter是怎么用的,怎么设计接口测试用例的
  • 数据挖掘示例
  • 【PHP】在ThinkPHP6中Swoole与FPM的简单性能测试对比
  • 论文写作学习--POLYGCL
  • 【高等数学】无穷级数
  • 计算机网络——无连接传输UDP
  • DS几大常见排序讲解和实现(下)(15)
  • 电脑视频剪辑大比拼,谁更胜一筹?
  • 计算机毕业设计 基于Web的景区管理系统的设计与实现 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试
  • 计算生物学与生物信息学漫谈-2-测序深度/读长质量和Fasta处理
  • 基于SSM+微信小程序的电子点餐管理系统(点餐1)
  • IO进程---day5
  • ROS理论与实践学习笔记——5 ROS机器人系统仿真之URDF(Unified Robot Description Format)语法详解
  • 常见SQL注入攻击示例与原理及其防御措施
  • Node.js 中的 WebSocket 底层实现
  • MySQl数据库的基本操作
  • Egg.js 项目的合理 ESLint 配置文件模板
  • 算法专题七: 分治归并
  • 一个基于vue功能强大的表格组件--vxe-table的二次封装
  • CSS网页布局(重塑网页布局)
  • 计算机网络:数据链路层 —— 以太网(Ethernet)
  • 考研前所学c语言02(2024/10/16)
  • R语言绘图——坐标轴及图例
  • JDK中socket源码解析
  • Ansible自动化运维项目实战指南
  • MySQL【知识改变命运】10
  • Java学习教程,从入门到精通, Java 基础语法(4)
  • 反编译工具-Jclasslib的使用,与Java方法调用的探索