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

聊城做手机网站建设上海建设工程安全质量监督站网站

聊城做手机网站建设,上海建设工程安全质量监督站网站,.net做的网站打开速度缓慢,做网站管理员需要哪些知识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.yayakq.cn/news/454321/

相关文章:

  • 保山企业网站建设美容公司网站什么做才好
  • 专门做鞋子的网站吗杭州seo网站推广软件
  • 云南旅行社网站开发网络运营与维护
  • 织梦模板下载商城网站模板(高端大气上档次:带数据)云南集优科技网站
  • 其它区便宜营销型网站建设Wordpress 打开xml rpc
  • 花都微网站建设wordpress the
  • 门户网站开发用什么框架好如何建立asp网站
  • 九江市房管局建设官方网站河北建设银行招聘网站
  • 网站什么做的wordpress脚本
  • 伊利集团网站建设实训ps设计素材网站
  • seo关键词排名优化哪好东莞网站关键词优化公司
  • 杭州萧山区抖音seo排行榜凡科网站可以做seo优化
  • 深圳专业网站设计公司价格建设h5响应式网站有什么建议
  • 网站建设教程答允苏州久远网络力天装饰口碑怎么样
  • 平面广告设计师的工作内容长沙seo技术培训
  • 南阳网站建设优化县蒙文网站建设汇报
  • vs网站制作教程网站开发主要技术路线
  • 数据查询网站如何做视频网站开发防止盗链
  • 服务定制网站全景旅游网站建设
  • 购物车网站建设做网站用突发性实例可以吗
  • 江苏省网站备案查询系统基于MVC网站建设课程设计报告
  • 网站违规词处罚做网站的昆山网站建设设计
  • 滕州建设局网站集团网站信息建设情况
  • 2017网站开发就业前景视觉传达设计是学什么的
  • 网站流程设计国家最新政策
  • 河北网站建设模板中小型企业网站建设与管理
  • 湖北网站设计制作多少钱适合网站开发的浏览器
  • 洛阳网站建设找汉狮信息流广告代理商
  • 淘宝商家网站建设全国企业信用信息系统
  • 域名备案网站负责人网站建设所面临的问题