webpack如何处理css

一、准备工作

新建目录

添加样式

css 复制代码
.word {
    color: red;
}

index.js添加dom元素,添加一个css word

javascript 复制代码
import './css/index.css';

const div = document.createElement("div");
div.innerText = "hello word!!!";
div.className = "word";
document.body.appendChild(div);

然后把打包后的文件引入index.html

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script src="./build/build.js"></script>
</body>
</html>

这个时候打包npm run build就会报错

这个时候就需要loader处理我们的css

二、css-loader

首先安装我们需要的loader

javascript 复制代码
pnpm i -D css-loader

添加配置文件,test正则匹配文件,loader对应我们的loader名称

javascript 复制代码
const path = require("path");

/**
 * 类型提示
 * @type {import("webpack").Configuration}
 */
const config = {
  entry: "./src/index.js",
  output: {
    filename: "build.js",
    path: path.resolve(__dirname, "./build"),
  },
  module: {
    rules: [
      {
        test: /\.css$/, //正则匹配文件
        use: [
          {
            loader: "css-loader",
          }
        ],
      },
    ],
  },
};
module.exports = config;

这个时候打包会发现界面的样式没有成功

这是因为css-loader只是处理,没有把我们的样式引入到对应的文件,我们需要另一个loader处理

三、style-loader

先安装后引入

html 复制代码
pnpm i -D style-loader
javascript 复制代码
module: {
    rules: [
      {
        test: /\.css$/, //正则匹配文件
        use: [
          {
            loader: 'style-loader',
          },
          {
            loader: "css-loader",
          },
        ],
      },
    ],
  },

我们需要注意loader的顺序,从下往上执行,我们先处理css然后通过style-loader注入样式

运行npm run build发现样式生效了

相关推荐
半生过往26 分钟前
2025 前端动效实战指南:Vue Bits & React Bits 深度拆解(功能 / 复用 / 高频问题处理)
前端·vue.js·react.js
程序员包打听29 分钟前
Vitest 4.0 重磅发布:Browser Mode 正式稳定,前端测试进入新纪元
前端
BumBle30 分钟前
UniApp 多页面编译优化:编译时间从10分钟到1分钟
前端
星链引擎33 分钟前
大语言模型的技术突破与稳定 API 生态的构建
前端
还是大剑师兰特34 分钟前
TypeScript 面试题及详细答案 100题 (71-80)-- 模块与命名空间
前端·javascript·typescript
BumBle34 分钟前
使用 SortableJS 实现vue3 + Element Plus 表格拖拽排序
前端·vue.js·element
玉宇夕落34 分钟前
HTML5 音乐敲击乐静态界面
前端
海在掘金6112734 分钟前
告别"拼写错误":TS如何让你的代码"字字精准"
前端
用户479492835691535 分钟前
什么是XSS攻击,怎么预防,一篇文章带你搞清楚
前端·javascript·安全
摸着石头过河的石头36 分钟前
深入理解JavaScript事件流:从DOM0到DOM3的演进之路
前端·javascript·性能优化