Plugins

플러그인은 webpack의 기본입니다. Webpack 자체는 webpack 설정에서 사용하는 것과 동일한 플러그인 시스템으로 구축되어 있습니다.

로더가 할 수 없는 다른 작업을 수행할 목적으로 제공됩니다.

Anatomy

webpack 플러그인은 apply 메서드를 가지고 있는 객체입니다. apply 메서드는 webpack 컴파일러에 의해 호출되며, 전체 컴파일 라이프사이클에 접근 할 수 있습니다.

ConsoleLogOnBuildWebpackPlugin.js

const pluginName = "ConsoleLogOnBuildWebpackPlugin";

class ConsoleLogOnBuildWebpackPlugin {
  apply(compiler) {
    compiler.hooks.run.tap(pluginName, (compilation) => {
      console.log("The webpack build process is starting!");
    });
  }
}

module.exports = ConsoleLogOnBuildWebpackPlugin;

컴파일러 훅의 탭 메서드의 첫 번째 파라미터는 플러그인 이름의 카멜화된 버전으로 작성하는 것이 좋습니다. 모든 훅에서 재사용 할 수 있도록 하기 위해서 상수를 사용하는 것이 좋습니다.

Usage

플러그인은 매개변수 및 옵션을 사용할 수 있으므로, webpack 설정에서 plugins 속성에 새로운 인스턴스로 전달해야 합니다.

webpack을 사용하는 방법에 따라 여러 가지 방법으로 플러그인을 사용 할 수 있습니다.

Configuration

webpack.config.js

const path = require("node:path");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const webpack = require("webpack"); // 빌트인 플러그인에 접근하기 위함

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은 컴파일하는 동안 리포트를 사용자 정의로 생성 할 수 있으며 HtmlWebpackPluginscript를 사용하여 my-first-webpack.bundle.js 파일을 포함하는 HTML 파일을 생성합니다.

Node API

Node API를 사용할 때 설정의 플러그인 속성을 통해 플러그인을 전달 할 수도 있습니다.

some-node-script.js

const webpack = require("webpack"); // webpack 런타임에 접근하기 위함
const configuration = require("./webpack.config.js");

const compiler = webpack(configuration);

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

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

7 Contributors

TheLarkInnjhnnsrouzbeh84johnstewMisterDevbyzykchenxsan

Translators