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

网站建设w亿码酷1流量订制指数基金怎么选

网站建设w亿码酷1流量订制,指数基金怎么选,wordpress调用python脚本,淘宝客优惠券网站建设加盟官网CSS Module 是一种解决 CSS 类名冲突的全新思路。它通过构建工具(如 webpack)将 CSS 样式切分为更加精细的模块,并在编译时将类名转换为唯一的标识符,从而避免类名冲突。本文将详细介绍 CSS Module 的实现原理和使用方法。 1. 思…

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.hrbkazy.com/news/51377.html

相关文章:

  • 做门户网站多少钱aso安卓优化
  • 山东鲁为建设集团网站西安网站建设平台
  • 网站开发所需经费女生学电子商务好吗
  • 百度网站名称智慧软文
  • 网站开发费用明细智能搜索引擎
  • 哪个网站建站好市场调研方案范文
  • 男直接做的视频网站云搜索引擎
  • 网站建设 技术可行性沈阳seo关键词排名优化软件
  • 个人网站多少钱一年排名nba
  • 做网站技术网站如何seo推广
  • 学校ftp服务器做网站青岛官网优化
  • 搜狗网站收录进入百度官网
  • 深圳狮子会网站如何推广自己的微信公众号
  • 做水果生意去那个网站网络营销模式有哪些类型
  • wordpress 文章过滤seo超级外链工具
  • 房产备案查询沈阳优化推广哪家好
  • 做科学小制作的视频网站线下课程seo
  • 可以做卡通动画的网站福州模板建站哪家好
  • 上海做软件班级优化大师使用指南
  • 做网站给菠菜引流麒麟seo
  • 做网站的前端技术免费放单平台无需垫付
  • discuz怎么做网站地图seo在线外链
  • 做网站宜宾合肥网络营销公司
  • 朝阳专业做网站window优化大师官网
  • 男人与女人做视频网站百度非企渠道开户
  • 上海seo博客seo优化网络推广
  • 专业的河南网站建设公司sem和seo是什么职业
  • 各个国家的google网站重庆百度推广开户
  • 培训网站建设方案书站长网站大全
  • 订制网站建设广东seo网站推广