【Nova UI】三、探秘 BEM:解锁前端 CSS 命名的高效密码
序言
在上一篇文章中,我们一步一个脚印,扎实地完成了 Vue 组件库搭建的环境搭建工作,从 pnpm 的精妙运用到 TypeScript 的细致配置✍️,每个环节都为组件库的诞生筑牢根基。现在,当我们把目光聚焦到组件库的样式设计时,一种极为实用且风靡前端界的 CSS 命名规范 ——BEM 规范,自然而然地进入了我们的视野。它就如同 CSS 世界里的导航灯塔🚢,为我们在样式管理的复杂海洋中指引方向,接下来,让我们一同深入探寻 BEM 规范的奥秘。
什么是BEM规范?
在前端开发领域,随着项目规模的不断扩大和代码复杂度的增加,如何有效地组织和管理 CSS 样式成为了一个关键问题。BEM 规范应运而生,它为我们提供了一种清晰、结构化的方式来命名和管理 CSS 类,极大地提升了代码的可维护性和可扩展性💻。
BEM 分别代表什么?
BEM 即 Block(块)、Element(元素)、Modifier(修饰符)的缩写,是由 Yandex 团队提出的一种 CSS 命名规范。它通过一种特定的命名约定,让我们能够直观地从类名中了解到 HTML 元素的结构和样式信息📏。
块(Block)
元素是块的有机组成部分,无法脱离块单独存在,且只有在块的语境中才有意义。对于按钮块来说,若按钮内部包含图标和文本,那么图标和文本就可看作按钮的元素。通过在块的类名后添加双下划线__来表示元素类名,如按钮中的图标元素可写成button__icon ,文本元素可写成button__text。HTML 代码如下:
<button class="button">点击我</button>
.button {background-color: #007BFF;color: white;padding: 10px 20px;border: none;border - radius: 5px;cursor: pointer;
}
元素(Element)
元素是块的有机组成部分,无法脱离块单独存在,且只有在块的语境中才有意义。对于按钮块来说,若按钮内部包含图标和文本,那么图标和文本就可看作按钮的元素。通过在块的类名后添加双下划线__来表示元素类名,如按钮中的图标元素可写成button__icon ,文本元素可写成button__text。HTML 代码如下:
<button class="button"><i class="button__icon"></i><span class="button__text">提交</span>
</button>
.button__icon {display: inline - block;margin - right: 5px;/* 这里可以添加图标的具体样式,如背景图、大小等 */
}
.button__text {display: inline - block;font - size: 16px;
}
修饰符(Modifier)
修饰符用于刻画块或元素在外观、状态或行为上的变化。对于按钮块而言,它可能有不同颜色、大小或禁用状态。在块或元素的类名后加上双连字符--来表示修饰符类名。例如,绿色的按钮可写成button--green,大尺寸的按钮可写成button--large,禁用状态的按钮可写成button--disabled。HTML 代码如下:
<button class="button button--green">绿色按钮</button>
<button class="button button--large">大按钮</button>
<button class="button button--disabled">禁用按钮</button>
.button--green {background-color: green;
}
.button--large {padding: 15px 30px;font - size: 18px;
}
.button--disabled {background-color: #ccc;color: #999;cursor: not - allowed;
}
BEM 规范的优势
提高代码的可读性和可维护性📖
BEM 规范下的类名,如同清晰的注释,让我们一眼便能知晓元素的结构与所属关系。看到button__text--highlighted,脑海中立刻浮现出这是按钮内被突出显示的文本。当需要修改样式时,借助类名能迅速定位到对应的 CSS 代码,大幅缩短排查与修改时间。
便于团队协作🤝
在多人协作的开发项目中,BEM 规范是统一的语言,确保每位成员遵循相同的命名规则。新成员加入项目时,也能凭借这套规范快速理解代码结构,有效减少因命名差异导致的沟通成本与错误,提升团队整体开发效率。
增强代码的可扩展性🚀
随着项目的演进,新增样式或功能是常有的事。BEM 规范让这一过程变得轻松自如,只需添加新的修饰符类,便不会对其他部分的样式产生干扰。例如,为按钮添加--rounded - corners修饰符表示圆角按钮,不会破坏原有的按钮样式体系。
方便进行样式复用♻️
块和元素的独立性,使得它们如同可复用的积木,能在不同项目或页面中重复使用。以button块为例,在多个场景中,只需依据需求添加不同修饰符,就能轻松适配各种样式需求,避免了重复编写代码,提高开发效率。
使用 BEM 规范的注意事项
避免过度嵌套
尽管 BEM 规范允许元素在块内嵌套,但过度嵌套会使类名冗长繁杂,增加代码理解难度。应秉持简洁原则,避免不必要的层级嵌套。比如对于按钮,如果内部结构较为复杂,要思考是否有更合理的方式拆分或组织,而不是一味地进行多层嵌套。
合理使用修饰符
修饰符应精准用于表示真实的外观、状态或行为变化,避免滥用。杜绝出现意义相近的修饰符,如button--red和button--scarlet,这类情况可通过 CSS 变量等方式实现颜色微调,保持代码简洁与规范。同时,修饰符的命名应具有清晰的语义,让人一看便知其代表的样式变化。
结合其他 CSS 技术
BEM 规范主要聚焦于命名约定,在实际开发中,需与其他 CSS 技术协同作战。比如 CSS 预处理器(Sass、Less)、CSS 模块化等。使用 CSS 预处理器能更便捷地管理变量、混合宏等,与 BEM 规范结合,能发挥出更大优势,提升开发效率与代码质量。例如,通过 Sass 的变量功能,可以方便地统一管理按钮的颜色、尺寸等基础样式,再结合 BEM 规范的命名,使代码更加清晰和易于维护。
综上所述,BEM 规范在前端开发中是一项极具实用价值的技术。它凭借清晰的命名规则,为我们构建了一套高效的 CSS 管理模式,在提升代码质量、增进团队协作以及适应项目变化等方面,都发挥着举足轻重的作用。无论是初涉前端开发的新手,还是经验丰富的资深开发者,深入学习并熟练应用 BEM 规范,都将为自身的技术提升与项目开发带来显著助益🌟。
🦀🦀感谢看官看到这里,如果觉得文章不错的话🙌,点个关注不迷路⭐。
诚邀您加入我的微信技术交流群🎉,群里都是志同道合的开发者👨💻,大家能一起交流分享摸鱼🐟。期待与您在群里相见🚀,咱们携手在开发路上共同进步✨ !
👉点我
感谢各位大侠一路相伴,实在感激! 不瞒您说,在下还有几个开源项目 📦,它们就像精心培育的幼苗 🌱,急需您的浇灌。要是您瞧着还不错,麻烦动动手指,给它们点亮几颗 Star ⭐,您的支持就是它们成长的最大动力,在此谢过各位大侠啦!
Nova UI组件库:https://github.com/gmingchen/nova-ui- 基于 Vue3 + Element-plus 管理后台基础功能框架
- 预览:https://admin.gumingchen.icu
- Github:https://github.com/gmingchen/agile-admin
- Gitee:https://gitee.com/shychen/agile-admin
- 基础版后端:https://github.com/gmingchen/java-spring-boot-admin
- 文档:http://admin.gumingchen.icu/doc/
- 基于 Vue3 + Element-plus + websocket 即时聊天系统
- 预览:https://chatterbox.gumingchen.icu/
- Github:https://github.com/gmingchen/chatterbox
- Gitee:https://gitee.com/shychen/chatterbox
- 基于 node 开发的后端服务:https://github.com/gmingchen/node-server
相关文章:
【Nova UI】三、探秘 BEM:解锁前端 CSS 命名的高效密码
序言 在上一篇文章中,我们一步一个脚印,扎实地完成了 Vue 组件库搭建的环境搭建工作,从 pnpm 的精妙运用到 TypeScript 的细致配置✍️,每个环节都为组件库的诞生筑牢根基。现在,当我们把目光聚焦到组件库的样式设计时…...
Qt中存储多规则形状图片
在Qt中,您可以通过多种方式处理和存储具有非矩形(多规则形状)的图片。以下是几种主要实现方案: 1. 使用透明通道存储不规则形状 实现方法 // 创建带透明背景的QPixmap QPixmap pixmap(400, 400); pixmap.fill(Qt::transparent);QPainter painter(&…...
前端界面在线excel编辑器 。node编写post接口获取文件流,使用传参替换表格内容展示、前后端一把梭。
首先luckysheet插件是支持在线替换excel内容编辑得但是浏览器无法调用本地文件,如果只是展示,让后端返回文件得二进制文件流就可以了,直接使用luckysheet展示。 这里我们使用xlsx-populate得node简单应用来调用本地文件,自己写一个…...
核心知识——Spark核心数据结构:RDD
引入 通过前面的学习,我们对于Spark已经有一个基本的认识,并且搭建了一个本地的练习环境,因为本专栏的主要对象是数仓和数分,所以就不花大篇幅去写环境搭建等内容,当然,如果感兴趣的小伙伴可以留言&#x…...
Python如何为区块链治理注入智能与高效?
Python如何为区块链治理注入智能与高效? 引言 区块链治理作为一个新兴领域,旨在解决去中心化网络中的决策与协调问题。无论是以太坊的协议升级,还是DAO(去中心化自治组织)内部的投票机制,治理效率与公正性始终是核心挑战。然而,Python的灵活性与强大的生态系统为区块链…...
树莓派 —— 在树莓派4b板卡下编译FFmpeg源码,支持硬件编解码器(mmal或openMax硬编解码加速)
🔔 FFmpeg 相关音视频技术、疑难杂症文章合集(掌握后可自封大侠 ⓿_⓿)(记得收藏,持续更新中…) 正文 1、准备工作 (1)树莓派烧录RaspberryPi系统 (2)树莓派配置固定IP(文末) (3)xshell连接树莓派 (4)...
【Easylive】auditVideo方法详细解析
【Easylive】项目常见问题解答(自用&持续更新中…) 汇总版 auditVideo 方法是视频审核的核心方法,负责处理视频审核状态的变更、用户积分奖励、数据同步以及文件清理等操作。下面我将从功能、流程、设计思路等方面进行全面解析。 1. 方…...
【数据分享】中国3254座水库集水区特征数据集(免费获取)
水库在水循环、碳通量、能量平衡中扮演关键角色,实实在在地影响着我们的生活。其功能和环境影响高度依赖于地理位置、上游流域属性(如地形、气候、土地类型)和水库自身的动态特征(如水位、蒸发量)。但在此之前一直缺乏…...
Maven安装与配置完整指南
Maven安装与配置完整指南 1. 前言 Apache Maven 是一个强大的项目管理和构建工具,广泛应用于Java项目开发。它通过 POM(Project Object Model) 文件管理项目依赖,并提供了标准化的构建流程。 本文详细介绍 Maven的下载、安装、环境配置、镜像加速、IDE集成 以及 常见问题…...
我用Axure画了一个富文本编辑器,还带交互
最近尝试用Axure RP复刻了一个富文本编辑器,不仅完整还原了工具栏的各类功能,还通过交互设计实现了接近真实编辑器操作体验。整个设计过程聚焦功能还原与交互流畅性,最终成果令人惊喜。 编辑器采用经典的三区布局:顶部工具栏集成了…...
Uniapp自定义TabBar组件全封装实践与疑难问题解决方案
前言 在当前公司小程序项目中,我们遇到了一个具有挑战性的需求:根据不同用户身份动态展示差异化的底部导航栏(TabBar) 。这种多角色场景下的UI适配需求,在提升用户体验和实现精细化运营方面具有重要意义。 在技术调研…...
【PCB工艺】软件是如何控制硬件的发展过程
软件与硬件的关系密不可分,软件的需求不断推动硬件的发展,而硬件的进步又为软件创新提供了基础。 时光回溯到1854年,亨利戈培尔发明了电灯泡(1879年,托马斯阿尔瓦爱迪生找到了更合适的材料研制出白炽灯。)…...
Javascript代码压缩混淆工具terser详解
原始的JavaScript代码在正式的服务器上,如果没有进行压缩,混淆,不仅加载速度比较慢,而且还存在安全和性能问题. 因此现在需要进行压缩,混淆处理. 处理方案简单描述一下: 1. 使用 terser 工具进行 安装 terser工具: # npm 安装 npm install terser --save-dev# 或使用 yarn 安…...
【教程】如何利用bbbrisk一步一步实现评分卡
利用bbbrisk一步一步实现评分卡 一、什么是评分卡1.1.什么是评分卡1.2.评分卡有哪些 二、评分卡怎么弄出来的2.1.如何制作评分卡2.2.制作评分卡的流程 三、变量的分箱3.1.数据介绍3.2.变量自动分箱3.3.变量的筛选 四、构建评分卡4.1.评分卡实现代码4.2.评分卡表4.3.阈值表与分数…...
RAG优化:python从零实现Proposition Chunking[命题分块]让 RAG不再“断章取义”,从此“言之有物”!
🧠 向所有学习者致敬! “学习不是装满一桶水,而是点燃一把火。” —— 叶芝 我的博客主页: https://lizheng.blog.csdn.net 🌐 欢迎点击加入AI人工智能社区! 🚀 让我们一起努力,共创AI未来! 🚀 大家好,本篇要聊的是一个让 RAG不再“断章取义”的神奇技术——命…...
丝杆,同步带,链条选型(我要自学网)
这里的选型可以70%的正确率,正确率不高,但是选型速度会比较快。 1.丝杆选型 后面还有一堆计算公式,最终得出的结果是导程25,轴径25mm的丝杆。 丝杆选择长度时,还要注意细长比,长度/直径 一般为30到50。 2…...
【YOLO系列】基于YOLOv8的无人机野生动物检测
基于YOLOv8的无人机野生动物检测 1.前言 在野生动物保护、生态研究和环境监测领域,及时、准确地检测和识别野生动物对于保护生物多样性、预防人类与野生动物的冲突以及制定科学的保护策略至关重要。传统的野生动物监测方法通常依赖于地面巡逻、固定摄像头或无线传…...
一文详细讲解Python(详细版一篇学会Python基础和网络安全)
引言 在当今数字化时代,Python 作为一种简洁高效且功能强大的编程语言,广泛应用于各个领域,从数据科学、人工智能到网络安全等,都能看到 Python 的身影。而网络安全作为保障信息系统和数据安全的关键领域,其重要性不言…...
NFS 重传次数速率监控
这张图展示的是 NFS 重传次数速率监控,具体解释如下: 1. 指标含义 监控指标 node_nfs_rpc_retransmissions_total 统计 NFS(网络文件系统)通信中 RPC(远程过程调用)的重传次数,rate(node_nfs_…...
【Java】Hibernate的一级缓存
Session是有一个缓存, 又叫Hibernate的一级缓存 session缓存是由一系列的Java集合构成的。当一个对象被加入到Session缓存中,这个对象的引用就加入到了java的集合中,以后即使应用程序中的引用变量不再引用该对象,只要Session缓存不被清空&…...
学习笔记--(6)
import numpy as np import matplotlib.pyplot as plt from scipy.special import erfc# 设置参数 rho 0.7798 z0 4.25 # 确保使用大写 Z0,与定义一致def calculate_tau(z, z_prime, rho, s_values):return np.log(rho * z * z_prime * s_values / 2)# 定义 chi_…...
【QT5 网络编程示例】TCP 通信
文章目录 TCP 通信 TCP 通信 QT主要通过QTcpSocket 和 QTcpServer两个类实现服务器和客户端的TCP 通信。 QTcpSocket 是 Qt 提供的套接字类,看用于建立、管理和操作 TCP 连接。 常用方法 connectToHost(host, port):连接到指定服务器。disconnectFro…...
JWT在线解密/JWT在线解码 - 加菲工具
JWT在线解密/JWT在线解码 首先进入加菲工具 选择 “JWT 在线解密/解码” https://www.orcc.top 或者直接进入JWT 在线解密/解码 https://www.orcc.top/tools/jwt 进入功能页面 使用 输入对应的jwt内容,点击解码按钮即可...
【Linux】用户向硬件寄存器写入值过程理解
思考一下,当我们咋用户态向寄存器写入一个值,这个过程是怎么样的呢?以下是应用程序通过标准库函数(如 write()、ioctl() 或 mmap())向硬件寄存器写入值的详细过程,从用户空间到内核再到硬件的完整流程&…...
【Easylive】convertVideo2Ts 和 union 方法解析
【Easylive】项目常见问题解答(自用&持续更新中…) 汇总版 这两个方法是 transferVideoFile 中用于视频文件处理的核心辅助方法,下面我将结合它们在 transferVideoFile 中的使用场景进行详细解释。 1. convertVideo2Ts 方法解析 方法签…...
飞桨PP系列新成员PP-DocLayout开源,版面检测加速大模型数据构建,超百页文档图像一秒搞定
背景介绍 文档版面区域检测技术通过精准识别并定位文档中的标题、文本块、表格等元素及其空间布局关系,为后续文本分析构建结构化上下文,是文档图像智能处理流程的核心前置环节。随着大语言模型、文档多模态及RAG(检索增强生成)等…...
Java 锁机制详解:用“厕所门”和“防盗门”轻松理解多线程同步
Java 锁机制详解:用“厕所门”和“防盗门”轻松理解多线程同步 目录 锁的作用synchronized 关键字ReentrantLockReadWriteLockStampedLock避免死锁的诀窍总结与对比 锁的作用 生活中的例子:公共厕所一次只能进一人,门上的“有人/无人”标志…...
关于修改 vue Element admin、若依, 等后台管理系统模板的一些全局样式问题:
关于修改 vue Element admin、若依, 等后台管理系统模板的一些全局样式问题: 1、修改左侧菜单和顶部(菜单)的背景色、把背景色改为炫酷的背景图。 1)上传图片 src/assets/images/menu-icon.png、 src/assets/images/…...
并发多线程八股
并发多线程 1.Java里面的线程和操作系统的线程一样吗?2.Java的线程安全在三个方面体现:3.保证数据一致性的方案4.线程创建的方式1)Thread类2)Runnable接口3)Callable接口和FutureTask4)线程池(e…...
飞速(FS)HPC无损组网:驱动AI高性能计算网络转型升级
案例亮点 部署低功耗、高密度飞速(FS)以太网交换机,紧凑机身设计节省70%机房空间,冗余电源和智能风扇确保系统高可用性,有效优化散热和降低能耗。 支持25G/40G/100G多速率自适应交换架构,构建超低时延企业…...
