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

相关推荐
微信:137971205872 分钟前
web端手机录音
前端
齐 飞7 分钟前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
暮毅12 分钟前
10.Node.js连接MongoDb
数据库·mongodb·node.js
神仙别闹24 分钟前
基于tensorflow和flask的本地图片库web图片搜索引擎
前端·flask·tensorflow
GIS程序媛—椰子1 小时前
【Vue 全家桶】7、Vue UI组件库(更新中)
前端·vue.js
DogEgg_0011 小时前
前端八股文(一)HTML 持续更新中。。。
前端·html
ZL不懂前端1 小时前
Content Security Policy (CSP)
前端·javascript·面试
木舟10091 小时前
ffmpeg重复回听音频流,时长叠加问题
前端
王大锤43912 小时前
golang通用后台管理系统07(后台与若依前端对接)
开发语言·前端·golang
我血条子呢2 小时前
[Vue]防止路由重复跳转
前端·javascript·vue.js