การรวมไฟล์สไตล์ในเลย์เอาต์ด้วย Webpack
ตอนนี้มาทำให้ Webpack เชื่อมต่อ CSS bundle เข้ากับ HTML layout ของเว็บไซต์โดยอัตโนมัติกัน
สมมติว่าไฟล์ CSS สองไฟล์ถูกนำเข้าไปยัง entry point:
import './styles1.css';
import './styles2.css';
มาเริ่มตั้งค่าการรวมไฟล์เหล่านี้เป็น bundle เดียวกัน เริ่มจากทำการนำเข้าทุกสิ่งที่จำเป็น:
import path from 'path';
import MiniCssExtractPlugin from "mini-css-extract-plugin";
import HtmlWebpackPlugin from 'html-webpack-plugin';
ต่อไปทำการตั้งค่า:
export default {
context: path.resolve( 'src'),
entry: './index.js',
output: {
filename: 'build.[contenthash].js',
path: path.resolve('dist'),
},
plugins: [
new MiniCssExtractPlugin({
filename: 'build.[contenthash].css'
}),
new HtmlWebpackPlugin(),
],
module: {
rules: [
{
test: /\.css$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader'],
},
],
},
};
ผลลัพธ์หลังจาก build เราจะมี bundle ของสคริปต์และ bundle ของสไตล์ที่เชื่อมต่อแล้ว:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Webpack App</title>
<script defer src="build.4173b379c6d6ff439604.js"></script>
<link href="build.97299e5ee87c9c343a4c.css" rel="stylesheet">
</head>
<body>
</body>
</html>
เชื่อมต่อไฟล์ CSS สามไฟล์เข้ากับ entry point จัดการให้ไฟล์เหล่านี้ถูกรวมเป็น bundle เดียวกัน ตรวจสอบให้แน่ใจว่า bundle นี้จะถูกเชื่อมต่อกับไฟล์ layout โดยอัตโนมัติ