Више CSS бандлова у Webpack-у
Ако се више улазних тачак споји у једну датотеку, онда ће и датотека за CSS бити једна за њих. Ако, међутим, сакупљамо JavaScript у више бандлова, онда ће за сваки од њих бити сакупљена посебна CSS датотека.
Хајде да погледамо на примеру. Претпоставимо да имамо једну улазну тачку и да се у њу увозе неке датотеке стилова:
import './styles1-1.css';
import './styles1-2.css';
Претпоставимо да се у другу улазну тачку такође увозе стилови:
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'
})],
module: {
rules: [
{
test: /\.css$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader'],
},
],
},
};
Као резултат оваквих поставки биће сакупљено
два CSS бандла:
test1.398db7afe3b52e94bb25.css и
test2.1d12c304c284a752cb9a.css.
Направите три улазне тачке. Повежите на сваку њене CSS датотеке. Извршите сабирање и проверите шта ће бити резултат.