如何简单易懂学会webpack-plugin扩展

729 阅读1分钟

小知识,大挑战!本文正在参与“  程序员必备小知识  ”创作活动

本文同时参与 「掘力星计划」  ,赢取创作大礼包,挑战创作激励金

前言

继上一篇《loader实践之如何手把手实现一个loader》,对loader进行扩展。

plugin是 webpack 的支柱功能。webpack 自身也是构建于你在 webpack 配置中用到的相同的插件系统之上!

插件目的在于解决loader无法实现的其他事

用法

由于插件可以携带参数/选项,你必须在 webpack 配置中,向plugins属性传入一个new实例。

取决于你的 webpack 用法,对应有多种使用插件的方式。

剖析

webpack插件是一个具有apply方法的 JavaScript 对象。apply方法会被 webpack compiler 调用,并且在整个编译生命周期都可以访问 compiler 对象。

ConsoleLogOnBuildWebpackPlugin.js

const pluginName = 'ConsoleLogOnBuildWebpackPlugin';

class ConsoleLogOnBuildWebpackPlugin {
  apply(compiler) {
    compiler.hooks.run.tap(pluginName, (compilation) => {
      console.log('webpack 构建过程开始!');
    });
  }
}

module.exports = ConsoleLogOnBuildWebpackPlugin;

compiler hook 的 tap 方法的第一个参数,应该是驼峰式命名的插件名称。建议为此使用一个常量,以便它可以在所有 hook 中重复使用。

配置方式

webpack.config.js

const HtmlWebpackPlugin = require('html-webpack-plugin'); // 通过 npm 安装
const webpack = require('webpack'); // 访问内置的插件
const path = require('path');

module.exports = {
  entry: './path/to/my/entry/file.js',
  output: {
    filename: 'my-first-webpack.bundle.js',
    path: path.resolve(__dirname, 'dist'),
  },
  module: {
    rules: [
      {
        test: /.(js|jsx)$/,
        use: 'babel-loader',
      },
    ],
  },
  plugins: [
    new webpack.ProgressPlugin(),
    new HtmlWebpackPlugin({ template: './src/index.html' }),
  ],
};

ProgressPlugin用于自定义编译过程中的进度报告,HtmlWebpackPlugin将生成一个 HTML 文件,并在其中使用script引入一个名为my-first-webpack.bundle.js的 JS 文件。

其他

参考链接:webpack.docschina.org/concepts/pl…