位置: IT常识 - 正文

新安webpack插件后编译报错compiler.plugin is not a function(webpack插件执行顺序)

编辑:rootadmin
新安webpack插件后编译报错compiler.plugin is not a function

推荐整理分享新安webpack插件后编译报错compiler.plugin is not a function(webpack插件执行顺序),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:webpack5安装,webpack常用插件和loader,webpack常用插件以及作用,webpack安装,webpack常用插件以及作用,webpack安装,webpack插件怎么写,webpack插件怎么写,内容如对您有帮助,希望把文章链接给更多的朋友!

        安装使用generate-asset-webpack-plugin时报错TypeError:compiler.plugin is not a function,网上搜索了一下大概就是webpack5与这些插件不匹配。推荐的方法几乎都是换一个适配的插件版本,但我所需要的这个插件在npm上最近更新时间是7年前💔。等不着作者适配于是决定自己改。

 先看解决办法:主要也只是webpack升级后,触发钩子的写法变了而已

        找到报错的文件,搜索“compiler.plugin”定位到问题所在,修改写法(如下),打个补丁,提交一下✔️。

原先代码:

compiler.plugin('emit', function (compilation, cb) {})

修改后:

compiler.hooks.emit.tapAsync('GenerateAssetWebpackPlugin',(compilation,callback)=>{})

 在接触到问题之前对于webpack的使用仅在于配置代理服务器 😢 ,后面就大概记录一下修改的思考过程与新get到的知识点。【以下的“类似于”仅因为自己接触知识点的前后顺序,不在于本身发布前后顺序,我猜测wabpack肯定比vue早出现😂】

🌷 看到compiler的时候还不知道这是个啥东西,怎么就调了一个plugin方法。在当前文件没搜到后就开始了百度之旅(刚开始还以为plugin是创作者自定义的)。然后就了解到webpack的Compiler与Compilation 对象,个人理解Compiler粒度更大,类似于编译器实例,生命周期类似于APP的应用周期,整个生命周期只会执行一次(惨兮兮只有一条命)。

🌷 plugin是定义在webpack原型apply上的一个方法,用于调用webpack的钩子函数(类似于vue中mounted、created这种函数,会在特定的时间段进行调用),第一个参数为钩子函数名称,第二个参数为回调函数。关于钩子的种类及定义可查看文档compiler 钩子

新安webpack插件后编译报错compiler.plugin is not a function(webpack插件执行顺序)

 🌷 但在webpack5中,plugin方法被取消了!所以报错is not a function。输出一下complier对象也会发现无这个属性【具体complier有什么属性可以看看依赖里的这个文件node_modules\webpack\lib\Compiler.js)

🌷 既然触发生命周期的方法变了,更新一下为最新版本的写法就好了。查看文档作出修改,至少问题就解决了~

 看一下源码部分,以便更好的理解(node_modules\webpack\lib\Compiler.js)在类中一开始就定义了一个不可修改的钩子函数集合hooks,所以会区分complier钩子与compilation钩子。毕竟complier和compilation是两个不同类这里new的AsyncSeriesHook 又是什么​呢?字面意思是异步串行钩子,搜一下

 所以这里输出的这些函数都是tapable中的😮,具体看文档  tapable,简单过一下定义后就看看那个插件generate-asset-webpack-plugin吧。webpack太长了关于其什么阶段调用了什么钩子就等把webpack基础概念和原理补完再看👻

generate-asset-webpack-plugin

         这个代码挺少就看完了,查看官网自定义插件。自定义插件 | webpack 中文文档 | webpack 中文文档 | webpack 中文网

🧩 一个 JavaScript 命名函数或 JavaScript 类。

🧩 在插件函数的 prototype 上定义一个 apply 方法。

🧩 指定一个绑定到 webpack 自身的事件钩子。【这里就是指定的emit钩子

🧩 处理 webpack 内部实例的特定数据。【使用fs模块处理的

🧩 功能完成后调用 webpack 提供的回调。【callback结束异步操作

        其他的还好,主要是不理解为什么不直接在插件函数原型上定义apply ,而要去调用一个自执行函数并使用 defineProperty给apply方法定义一些数据属性,是为了将apply()方法做响应式嘛?😵是的话这么做有啥好处呢?

本文链接地址:https://www.jiuchutong.com/zhishi/296079.html 转载请保留说明!

上一篇:携程网移动端首页制作(html5+css3)(携程首页)

下一篇:vue3-setup语法糖之组件传参(defineProps、defineEmits、defineExpose)(vue3setup语法糖如何定义realtive数据)

  • 营改增抵减的销项税额会计分录
  • 退回企业所得税的账务处理
  • 房地产增值税税率是多少
  • 税务师考试科目搭配
  • 财产和行为税合并申报
  • 车辆购置税完税证明是什么
  • 怎么做掉公司账户的钱
  • 集体不动产和动产包括
  • 管理人员工作服计入什么科目
  • 不得抵扣的进项税额转出会计分录
  • 非贸税务备案
  • 没有土地使用证的房子拆迁怎么办
  • 未进行账务处理违反什么
  • 公户转到法人账户怎么做账
  • 出售股份是利好吗
  • 企业房租收入营改增
  • 企业申报表填写错误
  • 股权转让收益算利润吗
  • 电子发票截图可以吗
  • 库存现金进行清查
  • 个人使用过的设备有哪些
  • 1697509439
  • 一般贸易和进料加工的区别是什么
  • 公益性捐赠包括向脱贫地区捐赠吗
  • win11如何更改开始菜单位置
  • 华为鸿蒙系统怎么开启
  • 固定资产净值与原值的区别
  • 小米无线路由器internet黄灯
  • 分级核算下的建议有哪些
  • 外企借款投资利息高吗
  • 在途物资和材料采购属于存货吗
  • 苹果14数据线
  • w11怎么创建快捷方式
  • 人工单位怎么写
  • it最高工资
  • PHP:imagepalettetotruecolor()的用法_GD库图像处理函数
  • 企业发生的现金折扣应计入什么费用
  • 小规模纳税人免征增值税政策
  • phpcms 还有人用吗
  • is not defined at HTMLInputElement.onclick
  • web安全什么意思
  • 网商贷企业贷款条件
  • 基本户不注销会扣钱吗
  • 运输费用会计
  • 物业管理企业会计核算的特点如何?
  • 高新企业奖励金怎么开票
  • 什么是住房补贴,住房补贴如何办理?
  • 小规模纳税人转一般纳税人当月如何申报
  • 职工薪酬纳税调整
  • 车费多付了,怎么追回
  • 月末结转后应交税费应交增值税一般无余额
  • 本年利润的会计科目
  • 回购股票会导致所有者权益减少吗
  • 备查账簿有没有固定的格式
  • 新成立的公司需要年检吗
  • mysql详细介绍
  • Win10预览版怎么变回正式版
  • 如何封禁
  • win8怎么设置ip地址
  • 备份ubuntu系统
  • 微软十周年
  • nginx sbin目录
  • linux双网卡绑定原理
  • perfom.exe
  • nodejs image
  • dos命令中运行文件的命令
  • html概念及作用
  • nodejs操作mysql
  • node js入门
  • jquery 表格 排序
  • jquery 列表实现
  • node js连接数据库
  • javascript例题
  • unity 120帧
  • c#入门实例
  • unity spine换装
  • 获取python的运行结果
  • 安徽省电子发票开具流程
  • 专票购买方是对方公司吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设