Webpackの包括的な構成ガイド

Webpackパッケージングおよび構築ツールの最も詳細な構成ガイド、フロントエンドの友人、急いで、必要に応じてクローンを作成し、スターをクリックします。

基本的に、webpack は最新のJavaScriptアプリケーション用の静的モジュールバンドラーですwebpackはアプリケーションを処理するときに、アプリケーションに必要な各モジュールを含む依存関係グラフ(依存関係グラフ)を再帰的に作成し、これらすべてのモジュールを1つ以上のバンドルにパックします 

ここにするには、JavaScriptのモジュールとのWebPACKモジュールの詳細情報。

webpack v4.0.0以降、構成ファイルを導入する必要はありません。ただし、webpackは依然として高度に構成可能です。始める前に、4つのコアコンセプトを理解する必要があります

  • エントリ
  • 出力
  • ローダ
  • プラグイン

この文書の目的は与えることである高レベルの概要これらの概念を特定の概念の詳細関連するユースケースを提供しながら、

 

データのダウンロードアドレス:https//gitee.com/tglx/webpack.git

webpackドキュメントアドレス:https://webpack.js.org/concepts/

中国語のドキュメント:https//www.webpackjs.com/concepts/

開発環境構成の場合:

/*
  开发环境配置:能让代码运行
    运行项目指令:
      webpack 会将打包结果输出出去
      npx webpack-dev-server 只会在内存中编译打包,没有输出
*/

const { resolve } = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
  entry: './src/js/index.js',
  output: {
    filename: 'js/built.js',
    path: resolve(__dirname, 'build')
  },
  module: {
    rules: [
      // loader的配置
      {
        // 处理less资源
        test: /\.less$/,
        use: ['style-loader', 'css-loader', 'less-loader']
      },
      {
        // 处理css资源
        test: /\.css$/,
        use: ['style-loader', 'css-loader']
      },
      {
        // 处理图片资源
        test: /\.(jpg|png|gif)$/,
        loader: 'url-loader',
        options: {
          limit: 8 * 1024,
          name: '[hash:10].[ext]',
          // 关闭es6模块化
          esModule: false,
          outputPath: 'imgs'
        }
      },
      {
        // 处理html中img资源
        test: /\.html$/,
        loader: 'html-loader'
      },
      {
        // 处理其他资源
        exclude: /\.(html|js|css|less|jpg|png|gif)/,
        loader: 'file-loader',
        options: {
          name: '[hash:10].[ext]',
          outputPath: 'media'
        }
      }
    ]
  },
  plugins: [
    // plugins的配置
    new HtmlWebpackPlugin({
      template: './src/index.html'
    })
  ],
  mode: 'development',
  devServer: {
    contentBase: resolve(__dirname, 'build'),
    compress: true,
    port: 3000,
    open: true
  }
};

 

おすすめ

転載: blog.csdn.net/taotaobaobei/article/details/105255269