Kilka pakietów CSS w Webpack
Jeśli kilka punktów wejścia jest scalanych w jeden plik, to plik zbiorczy CSS będzie dla nich jeden. Jeśli jednak zbieramy JavaScript w kilka pakietów, to dla każdego z nich zostanie utworzony własny plik CSS.
Spójrzmy na przykład. Załóżmy, że mamy jeden punkt wejścia i do niego importowane są niektóre pliki stylów:
import './styles1-1.css';
import './styles1-2.css';
Załóżmy, że do drugiego punktu wejścia również importowane są style:
import './styles2-1.css';
import './styles2-2.css';
Napiszmy konfigurację:
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'
})],
module: {
rules: [
{
test: /\.css$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader'],
},
],
},
};
W wyniku takiej konfiguracji zostaną zebrane
dwa pakiety CSS:
test1.398db7afe3b52e94bb25.css i
test2.1d12c304c284a752cb9a.css.
Utwórz trzy punkty wejścia. Podłącz do każdego własne pliki CSS. Wykonaj budowę i sprawdź, co otrzymasz w wyniku.