Webpackでのレイアウト内の複数のスタイルバンドル
次に、エントリーポイントが複数あり、 それらがそれぞれ独自のバンドルに バンドルされる状況を考えてみましょう。 各エントリーポイントに独自のCSSファイルが 接続されているとします。 ご存知の通り、この場合、各エントリーポイントに対して 独自のCSSバンドルが作成されます。 Webpackはこれらの各バンドルを自動的に接続します。
実際に試してみましょう。 最初のエントリーポイントにスタイルを接続します:
import './styles1-1.css';
import './styles1-2.css';
2番目のエントリーポイントにスタイルを接続します:
import './styles2-1.css';
import './styles2-2.css';
設定を実行します:
export default {
context: path.resolve( 'src'),
entry: {
test1: './test1.js',
test2: './test2.js'
},
output: {
filename: '[name].[contenthash].js',
path: path.resolve('dist'),
},
plugins: [
new MiniCssExtractPlugin({
filename: '[name].[contenthash].css'
}),
new HtmlWebpackPlugin(),
],
module: {
rules: [
{
test: /\.css$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader'],
},
],
},
};
結果として、レイアウトファイルは 次のようになります:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Webpack App</title>
<script defer src="test1.18e856b0da2f7862ab19.js"></script>
<script defer src="test2.d12ade182c2989b4efa8.js"></script>
<link href="test1.398db7afe3b52e94bb25.css" rel="stylesheet">
<link href="test2.1d12c304c284a752cb9a.css" rel="stylesheet">
</head>
<body>
</body>
</html>
エントリーポイントを3つ作成してください。 各ポイントに3つのCSSファイルを接続してください。 ビルドを実行してください。 すべてのバンドルが自動的に接続されていることを確認してください。