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发现样式生效了

相关推荐
清汤饺子8 小时前
OpenClaw 本地部署教程 - 从 0 到 1 跑通你的第一只龙虾
前端·javascript·vibecoding
爱吃的小肥羊10 小时前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒11 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿12 小时前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人12 小时前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥12 小时前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪12 小时前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器
Mr_Mao12 小时前
我受够了混乱的 API 代码,所以我写了个框架
前端·api
小徐_233312 小时前
向日葵 x AI:把远程控制封装成 MCP,让 AI 替我远程控制设备
前端·人工智能
冴羽12 小时前
来自顶级大佬 TypeScript 之父的 7 个启示
前端·typescript