当前位置: 首页 > news >正文

CSS Module:告别类名冲突,拥抱模块化样式(5)

CSS Module 是一种解决 CSS 类名冲突的全新思路。它通过构建工具(如 webpack)将 CSS 样式切分为更加精细的模块,并在编译时将类名转换为唯一的标识符,从而避免类名冲突。本文将详细介绍 CSS Module 的实现原理和使用方法。

1. 思路

CSS Module 遵循以下思路解决类名冲突问题:

  1. 类名冲突:类名冲突往往发生在大型项目中。
  2. 构建工具:大型项目往往会使用构建工具(如 webpack)搭建工程。
  3. 模块化:构建工具允许将 CSS 样式切分为更加精细的模块。
  4. 变量机制:同 JS 的变量一样,每个 CSS 模块文件中难以出现冲突的类名,冲突的类名往往发生在不同的 CSS 模块文件中。
  5. 避免冲突:只需要保证构建工具在合并样式代码后不会出现类名冲突即可。
    在这里插入图片描述

2. 实现原理

在 webpack 中,作为处理 CSS 的 css-loader,它实现了 CSS Module 的思想。要启用 CSS Module,需要将 css-loader 的配置 modules 设置为 true

css-loader的实现方式如下:
在这里插入图片描述

原理极其简单,开启了css module后,css-loader会将样式中的类名进行转换,转换为一个唯一的hash值。

由于hash值是根据模块路径和类名生成的,因此,不同的css模块,哪怕具有相同的类名,转换后的hash值也不一样。

在这里插入图片描述

3. 如何应用样式

css module带来了一个新的问题:源代码的类名和最终生成的类名是不一样的,而开发者只知道自己写的源代码中的类名,并不知道最终的类名是什么,那如何应用类名到元素上呢?

为了解决这个问题,css-loader会导出原类名和最终类名的对应关系,该关系是通过一个对象描述的
在这里插入图片描述

3.1 示例

假设有一个 CSS 文件 style.css

.red {color: #f40;
}

在 JS 文件中,可以这样导入和应用类名:

import React from 'react';
import styles from './style.css';function App() {return (<div className={styles.red}>Hello, World!</div>);
}export default App;

4. 其他操作

4.1 全局类名

某些类名是全局的、静态的,不需要进行转换。可以在类名位置使用 :global 语法:

:global(.main) {/* 全局样式 */
}

使用了 :global 的类名不会进行转换,相反的,没有使用 :global 的类名,默认使用 :local

:local(.main) {/* 局部样式 */
}

4.2 控制最终的类名

大部分情况下,我们不需要控制最终的类名,因为控制它没有任何意义。如果一定要控制最终的类名,可以配置 css-loaderlocalIdentName

例如:

module.exports = {module: {rules: [{test: /\.css$/,use: ['style-loader',{loader: 'css-loader',options: {modules: true,localIdentName: '[local]_[hash:base64:5]'}}]}]}
};

5. 其他注意事项

  • 配合构建工具:CSS Module 通常配合构建工具(如 webpack)使用。
  • 避免嵌套类名:CSS Module 仅处理顶级类名,尽量不要书写嵌套的类名,也没有这个必要。
  • 不处理其他选择器:CSS Module 仅处理类名,不处理其他选择器。
  • 避免使用 ID 选择器:CSS Module 还会处理 ID 选择器,但任何时候都没有使用 ID 选择器的理由。
  • 命名规范:使用了 CSS Module 后,只要能做到让类名望文知意即可,不需要遵守其他任何的命名规范。

6. 总结

通过本课程,你已经了解了 CSS Module 的基本概念、实现原理和使用方法。CSS Module 提供了一种全新的方式来解决类名冲突问题,使得 CSS 代码更加模块化和可维护。

http://www.lryc.cn/news/485418.html

相关文章:

  • JavaSE常用API-日期(计算两个日期时间差-高考倒计时)
  • AutoDL上进行tensorboard可视化
  • 20.UE5UI预构造,开始菜单,事件分发器
  • 【C语言指南】C语言内存管理 深度解析
  • 前海华海金融创新中心的工地餐点探寻
  • 索引及练习
  • java版嘎嘎快充汽车单车充电系统源码系统jeecgboot
  • vueRouter路由切换时实现页面子元素动画效果, 左右两侧滑入滑出效果
  • MacOS编译hello_xr——记一次CMake搜索路径限制导致的ANDROID_NATIVE_APP_GLUE not found
  • 基于NI Vision和MATLAB的图像颜色识别与透视变换
  • 【Linux:IO多路复用(select、poll函数)
  • 计数排序(C语言)
  • LabVIEW弧焊参数测控系统
  • Android笔记(三十七):封装一个RecyclerView Item曝光工具——用于埋点上报
  • 【Linux】内核模版加载modprobe | lsmod
  • Android从Drawable资源Id直接生成Bitmap,Kotlin
  • 蓝桥杯——数组
  • 在Flutter中,禁止侧滑的方法
  • 黑盒测试案例设计方法的使用(1)
  • 第二十一章 TCP 客户端 服务器通信 - 客户端OPEN命令
  • pycharm报错:no module named cv2.cv2
  • Android音视频直播低延迟探究之:WLAN低延迟模式
  • docker 部署freeswitch(非编译方式)
  • OpenHarmony的公共事件
  • 深度学习transformer
  • 低成本出租屋5G CPE解决方案:ZX7981PG/ZX7981PM WIFI6千兆高速网络
  • 【黑马点评debug日记】redis登录跳转不成功
  • C#自定义特性-SQL
  • 协方差矩阵及其计算方法
  • 【OH】openHarmony开发环境搭建(基于windows子系统WSL)