最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Webpack4.0各个击破(7)plugin篇

    正文概述 掘金(JAVA_马指导)   2020-12-31   621

    一. plugin概述

    1.1 Plugin的作用

    plugin机制是webpack中另一个核心概念,它基于事件流框架tapable,你可以参考浏览器环境中的*【DOM事件模型】【SPA模型中的生命周期钩子】或是node环境中的【EventEmitter模块】*来理解其作用。plugin系统提供给开发者监听webpack生命周期并在特定事件触发时执行指定操作的能力。

    当然,要写一个真正能实现一定功能的插件,你还需要了解CompilerCompilation这两个概念,网上可以找到非常多相关的文章(《webpack-docs/plugin》)。

    1.2 Compiler

    从表现上看,Compiler暴露了和webpack整个生命周期相关的钩子,通过如下的方式访问:

    //基本写法
    compiler.hooks.someHook.tap(...)
    //如果希望在entry配置完毕后执行某个功能
    compiler.hooks.entryOption.tap(...)
    //如果希望在生成的资源输出到output指定目录之前执行某个功能
    compiler.hooks.emit.tap(...)
    
    

    webpack在重要的生命周期节点上都提供了事件钩子,我们可以借此加入一些自定义的功能。我们来编写一个插件,直观地看看webpack中涉及的钩子:

    //check-compiler-hooks-plugin.js
    const pluginName = 'checkCompilerHooksPlugin';
    module.exports = class checkCompilerHooksPlugin {
        apply(compiler){
            //打印出entryOption执行完毕时Compiler暴露的钩子
            for(var hook of Object.keys(compiler.hooks)){
                console.log(hook);
            }
        }
    }
    
    

    可以看到Compiler上可以使用的钩子(当然这种方式看到的钩子和实际触发顺序无关): Webpack4.0各个击破(7)plugin篇

    注意上图中Compiler.hooks暴露的事件钩子中有一个compilation,下一小节将解释它。

    1.3 Compilation

    Compilation暴露了与模块依赖有关的粒度更小的事件钩子,官方文档中的说法是模块会经历加载(loaded),封存(sealed),优化(optimized),分块(chunked),哈希(hashed)和重新创建(restored)这几个典型步骤,从上面的示例可以看到,compilationCompiler生命周期中的一个步骤,使用compilation相关钩子的通用写法为:

    compiler.hooks.compilation.tap('SomePlugin',function(compilation, callback){
        compilation.hooks.someOtherHook.tap('SomeOtherPlugin',function(){
            ....
        })
    });
    
    

    我们仿照上面的方法就可以查看到compilation对象上(compilation事件触发时,在回调函数中取得的引用)暴露的事件钩子。

    二. 如何写一个plugin

    根据webpack官方文档的说明,一个自定义的plugin需要包含:

    • 一个javascript命名函数
    • 插件函数的prototype上要有一个apply方法
    • 指定一个绑定到webpack自身的事件钩子
    • 注册一个回调函数来处理webpack实例中的指定数据
    • 处理完成后调用webpack提供的回调

    官网给出了一个基本的结构示例:

    //console-log-on-build-webpack-plugin.js
    const pluginName = 'ConsoleLogOnBuildWebpackPlugin';
    class ConsoleLogOnBuildWebpackPlugin {
        apply(compiler){
            compiler.hooks.run.tap(pluginName, compilation=>{
               console.log('webpack构建过程开始'); 
            });
        }
    }
    
    

    将其添加到webpack插件中后可以看到运行中触发了传入的回调函数: Webpack4.0各个击破(7)plugin篇

    四. 实战

    在《webpack4.0各个击破(4)——javascript & splitChunks》一文中,我们使用splitChunks功能对初始模块进行代码分割,在为多页面应用模型的html入口插入script标签时遇到了无法自动插入的问题,那么本节我们用一个webpack-dispatch-chunk-plugin来解决一下这个问题。

    Webpack4.0各个击破(7)plugin篇

    处理的逻辑就是利用html-webpack-plugin暴露的更改资源标签的事件钩子htmlWebpackPluginAlterAssetTags来进行资源处理,此时资源已经离过模块化和代码分割并已经在名称中加入了hash标记,只需要此时过滤掉名称中含有vendors且不包含相应入口名称的新的chunk即可,当然这只是一个基本功能,想要动态实现功能,还需要将上例中checkMap部分变为对Compiler或是Compilation上对应属性的引用,本篇不再赘述。

    【参考】

    [1] 《webpack之内部运行机制》


    起源地下载网 » Webpack4.0各个击破(7)plugin篇

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元