Categories: Webpack 教程

Webpack Plugin

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

插件目的在于解决 loader 无法实现的其他事。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 配置中,向 ​plugins​ 属性传入一个 ​new​ 实例。

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

配置方式

webpack.config.js

const HtmlWebpackPlugin = require(html-webpack-plugin);
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 文件。

Node API 方式

在使用 Node API 时,还可以通过配置中的 ​plugins​ 属性传入插件。

some-node-script.js

const webpack = require(webpack); // 访问 webpack 运行时(runtime)
const configuration = require(./webpack.config.js);

let compiler = webpack(configuration);

new webpack.ProgressPlugin().apply(compiler);

compiler.run(function (err, stats) {
  // ...
});

andy

前端小白,在Web176教程网这个平台跟大家一起学习,加油!

Share
Published by
andy

Recent Posts

自定义指令:聊聊vue中的自定义指令应用法则

今天我们来聊聊vue中的自定义…

4 天 ago

聊聊Vue中@click.stop和@click.prevent

一起来学下聊聊Vue中@cli…

2 周 ago

Nginx 基本操作:启动、停止、重启命令。

我们来学习Nginx基础操作:…

2 周 ago

Vue3:手动清理keep-alive组件缓存的方法

Vue3中手动清理keep-a…

2 周 ago

聊聊React和Vue组件更新的实现及区别

React 和 Vue 都是当…

3 周 ago