6 Webpack 插件

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

 

插件代码示例

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 构建过程开始!");

        });

}

}

compiler hook 的 tap 方法的第一个参数,应该是驼峰式命名的插件名称。

 

用法

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

根据你的 webpack 用法,这里有多种方式使用插件。

 

配置

通过webpack的配置应用插件

webpack.config.js

const HtmlWebpackPlugin = require('html-webpack-plugin'); //通过 npm 安装

const webpack = require('webpack'); //访问内置的插件

const path = require('path');

const config = {

  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.optimize.UglifyJsPlugin(),

    new HtmlWebpackPlugin({template: './src/index.html'})

  ]};

 

module.exports = config;

 

 

Node API

通过NodeApi来应用插件(不推荐)

some-node-script.js

  const webpack = require('webpack'); //访问 webpack 运行时(runtime)

  const configuration = require('./webpack.config.js');

 

  let compiler = webpack(configuration);

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

 

  compiler.run(function(err, stats) {

    // ...

  });

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值