插件 是webpack的backbone . webpack本身就是構建在一個同樣的插件系統 ,正如你使用的webpack配置一樣!
插件也為了實現加載器不能實現的其他任何功能。.
剖析
一個webpack 插件是一個擁有 apply
屬性的JavaScript對象。這個apply
屬性被webpack編譯器調用,提供給整個編譯生命周期訪問.
ConsoleLogOnBuildWebpackPlugin.js
function ConsoleLogOnBuildWebpackPlugin() {
};
ConsoleLogOnBuildWebpackPlugin.prototype.apply = function(compiler) {
compiler.plugin('run', function(compiler, callback) {
console.log("The webpack build process is starting!!!");
callback();
});
};
作為一個JavaScript開發人員,你可能還記得
Function.prototype.apply
方法。 因為這個方法你可以傳遞任何函數作為插件(this
將指向`編譯器')。 您可以使用此方式在配置中內置自定義插件。
用法
插件 可以帶入arguments/options,你必須傳遞一個new
實例到你的webpack配置的plugins
屬性中。
根據您使用webpack的方式,有多種方式使用插件。
配置
webpack.config.js
const HtmlWebpackPlugin = require('html-webpack-plugin'); //installed via npm
const webpack = require('webpack'); //to access built-in plugins
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)$/,
loader: 'babel-loader'
}
]
},
plugins: [
new webpack.optimize.UglifyJsPlugin(),
new HtmlWebpackPlugin({template: './src/index.html'})
]
};
module.exports = config;
Node API
即使使用Node API,用戶也應該通過配置中的
plugins
屬性傳遞插件。 使用compiler.apply
不是推薦的方法。
some-node-script.js
const webpack = require('webpack'); //to access webpack runtime
const configuration = require('./webpack.config.js');
let compiler = webpack(configuration);
compiler.apply(new webpack.ProgressPlugin());
compiler.run(function(err, stats) {
// ...
});
你知道么: 上面看到的例子與webpack runtime是非常類似的!。有很多很好的使用示例隱藏在webpack源代碼 中,你可以應用到自己的配置和腳本!