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

【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--redbutton--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 命名的高效密码

序言 在上一篇文章中&#xff0c;我们一步一个脚印&#xff0c;扎实地完成了 Vue 组件库搭建的环境搭建工作&#xff0c;从 pnpm 的精妙运用到 TypeScript 的细致配置✍️&#xff0c;每个环节都为组件库的诞生筑牢根基。现在&#xff0c;当我们把目光聚焦到组件库的样式设计时…...

Qt中存储多规则形状图片

在Qt中&#xff0c;您可以通过多种方式处理和存储具有非矩形(多规则形状)的图片。以下是几种主要实现方案&#xff1a; 1. 使用透明通道存储不规则形状 实现方法 // 创建带透明背景的QPixmap QPixmap pixmap(400, 400); pixmap.fill(Qt::transparent);QPainter painter(&…...

前端界面在线excel编辑器 。node编写post接口获取文件流,使用传参替换表格内容展示、前后端一把梭。

首先luckysheet插件是支持在线替换excel内容编辑得但是浏览器无法调用本地文件&#xff0c;如果只是展示&#xff0c;让后端返回文件得二进制文件流就可以了&#xff0c;直接使用luckysheet展示。 这里我们使用xlsx-populate得node简单应用来调用本地文件&#xff0c;自己写一个…...

核心知识——Spark核心数据结构:RDD

引入 通过前面的学习&#xff0c;我们对于Spark已经有一个基本的认识&#xff0c;并且搭建了一个本地的练习环境&#xff0c;因为本专栏的主要对象是数仓和数分&#xff0c;所以就不花大篇幅去写环境搭建等内容&#xff0c;当然&#xff0c;如果感兴趣的小伙伴可以留言&#x…...

Python如何为区块链治理注入智能与高效?

Python如何为区块链治理注入智能与高效? 引言 区块链治理作为一个新兴领域,旨在解决去中心化网络中的决策与协调问题。无论是以太坊的协议升级,还是DAO(去中心化自治组织)内部的投票机制,治理效率与公正性始终是核心挑战。然而,Python的灵活性与强大的生态系统为区块链…...

树莓派 —— 在树莓派4b板卡下编译FFmpeg源码,支持硬件编解码器(mmal或openMax硬编解码加速)

🔔 FFmpeg 相关音视频技术、疑难杂症文章合集(掌握后可自封大侠 ⓿_⓿)(记得收藏,持续更新中…) 正文 1、准备工作 (1)树莓派烧录RaspberryPi系统 (2)树莓派配置固定IP(文末) (3)xshell连接树莓派 (4)...

【Easylive】auditVideo方法详细解析

【Easylive】项目常见问题解答&#xff08;自用&持续更新中…&#xff09; 汇总版 auditVideo 方法是视频审核的核心方法&#xff0c;负责处理视频审核状态的变更、用户积分奖励、数据同步以及文件清理等操作。下面我将从功能、流程、设计思路等方面进行全面解析。 1. 方…...

【数据分享】中国3254座水库集水区特征数据集(免费获取)

水库在水循环、碳通量、能量平衡中扮演关键角色&#xff0c;实实在在地影响着我们的生活。其功能和环境影响高度依赖于地理位置、上游流域属性&#xff08;如地形、气候、土地类型&#xff09;和水库自身的动态特征&#xff08;如水位、蒸发量&#xff09;。但在此之前一直缺乏…...

Maven安装与配置完整指南

Maven安装与配置完整指南 1. 前言 Apache Maven 是一个强大的项目管理和构建工具,广泛应用于Java项目开发。它通过 POM(Project Object Model) 文件管理项目依赖,并提供了标准化的构建流程。 本文详细介绍 Maven的下载、安装、环境配置、镜像加速、IDE集成 以及 常见问题…...

我用Axure画了一个富文本编辑器,还带交互

最近尝试用Axure RP复刻了一个富文本编辑器&#xff0c;不仅完整还原了工具栏的各类功能&#xff0c;还通过交互设计实现了接近真实编辑器操作体验。整个设计过程聚焦功能还原与交互流畅性&#xff0c;最终成果令人惊喜。 编辑器采用经典的三区布局&#xff1a;顶部工具栏集成了…...

Uniapp自定义TabBar组件全封装实践与疑难问题解决方案

前言 在当前公司小程序项目中&#xff0c;我们遇到了一个具有挑战性的需求&#xff1a;根据不同用户身份动态展示差异化的底部导航栏&#xff08;TabBar&#xff09; 。这种多角色场景下的UI适配需求&#xff0c;在提升用户体验和实现精细化运营方面具有重要意义。 在技术调研…...

【PCB工艺】软件是如何控制硬件的发展过程

软件与硬件的关系密不可分&#xff0c;软件的需求不断推动硬件的发展&#xff0c;而硬件的进步又为软件创新提供了基础。 时光回溯到1854年&#xff0c;亨利戈培尔发明了电灯泡&#xff08;1879年&#xff0c;托马斯阿尔瓦爱迪生找到了更合适的材料研制出白炽灯。&#xff09;…...

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%的正确率&#xff0c;正确率不高&#xff0c;但是选型速度会比较快。 1.丝杆选型 后面还有一堆计算公式&#xff0c;最终得出的结果是导程25&#xff0c;轴径25mm的丝杆。 丝杆选择长度时&#xff0c;还要注意细长比&#xff0c;长度/直径 一般为30到50。 2…...

【YOLO系列】基于YOLOv8的无人机野生动物检测

基于YOLOv8的无人机野生动物检测 1.前言 在野生动物保护、生态研究和环境监测领域&#xff0c;及时、准确地检测和识别野生动物对于保护生物多样性、预防人类与野生动物的冲突以及制定科学的保护策略至关重要。传统的野生动物监测方法通常依赖于地面巡逻、固定摄像头或无线传…...

一文详细讲解Python(详细版一篇学会Python基础和网络安全)

引言 在当今数字化时代&#xff0c;Python 作为一种简洁高效且功能强大的编程语言&#xff0c;广泛应用于各个领域&#xff0c;从数据科学、人工智能到网络安全等&#xff0c;都能看到 Python 的身影。而网络安全作为保障信息系统和数据安全的关键领域&#xff0c;其重要性不言…...

NFS 重传次数速率监控

这张图展示的是 NFS 重传次数速率监控&#xff0c;具体解释如下&#xff1a; 1. 指标含义 监控指标 node_nfs_rpc_retransmissions_total 统计 NFS&#xff08;网络文件系统&#xff09;通信中 RPC&#xff08;远程过程调用&#xff09;的重传次数&#xff0c;rate(node_nfs_…...

【Java】Hibernate的一级缓存

Session是有一个缓存, 又叫Hibernate的一级缓存 session缓存是由一系列的Java集合构成的。当一个对象被加入到Session缓存中&#xff0c;这个对象的引用就加入到了java的集合中&#xff0c;以后即使应用程序中的引用变量不再引用该对象&#xff0c;只要Session缓存不被清空&…...

学习笔记--(6)

import numpy as np import matplotlib.pyplot as plt from scipy.special import erfc# 设置参数 rho 0.7798 z0 4.25 # 确保使用大写 Z0&#xff0c;与定义一致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 提供的套接字类&#xff0c;看用于建立、管理和操作 TCP 连接。 常用方法 connectToHost(host, port)&#xff1a;连接到指定服务器。disconnectFro…...

JWT在线解密/JWT在线解码 - 加菲工具

JWT在线解密/JWT在线解码 首先进入加菲工具 选择 “JWT 在线解密/解码” https://www.orcc.top 或者直接进入JWT 在线解密/解码 https://www.orcc.top/tools/jwt 进入功能页面 使用 输入对应的jwt内容&#xff0c;点击解码按钮即可...

【Linux】用户向硬件寄存器写入值过程理解

思考一下&#xff0c;当我们咋用户态向寄存器写入一个值&#xff0c;这个过程是怎么样的呢&#xff1f;以下是应用程序通过标准库函数&#xff08;如 write()、ioctl() 或 mmap()&#xff09;向硬件寄存器写入值的详细过程&#xff0c;从用户空间到内核再到硬件的完整流程&…...

【Easylive】convertVideo2Ts 和 union 方法解析

【Easylive】项目常见问题解答&#xff08;自用&持续更新中…&#xff09; 汇总版 这两个方法是 transferVideoFile 中用于视频文件处理的核心辅助方法&#xff0c;下面我将结合它们在 transferVideoFile 中的使用场景进行详细解释。 1. convertVideo2Ts 方法解析 方法签…...

飞桨PP系列新成员PP-DocLayout开源,版面检测加速大模型数据构建,超百页文档图像一秒搞定

背景介绍 文档版面区域检测技术通过精准识别并定位文档中的标题、文本块、表格等元素及其空间布局关系&#xff0c;为后续文本分析构建结构化上下文&#xff0c;是文档图像智能处理流程的核心前置环节。随着大语言模型、文档多模态及RAG&#xff08;检索增强生成&#xff09;等…...

Java 锁机制详解:用“厕所门”和“防盗门”轻松理解多线程同步

Java 锁机制详解&#xff1a;用“厕所门”和“防盗门”轻松理解多线程同步 目录 锁的作用synchronized 关键字ReentrantLockReadWriteLockStampedLock避免死锁的诀窍总结与对比 锁的作用 生活中的例子&#xff1a;公共厕所一次只能进一人&#xff0c;门上的“有人/无人”标志…...

关于修改 vue Element admin、若依, 等后台管理系统模板的一些全局样式问题:

关于修改 vue Element admin、若依&#xff0c; 等后台管理系统模板的一些全局样式问题&#xff1a; 1、修改左侧菜单和顶部&#xff08;菜单&#xff09;的背景色、把背景色改为炫酷的背景图。 1&#xff09;上传图片 src/assets/images/menu-icon.png、 src/assets/images/…...

并发多线程八股

并发多线程 1.Java里面的线程和操作系统的线程一样吗&#xff1f;2.Java的线程安全在三个方面体现&#xff1a;3.保证数据一致性的方案4.线程创建的方式1&#xff09;Thread类2&#xff09;Runnable接口3&#xff09;Callable接口和FutureTask4&#xff09;线程池&#xff08;e…...

飞速(FS)HPC无损组网:驱动AI高性能计算网络转型升级

案例亮点 部署低功耗、高密度飞速&#xff08;FS&#xff09;以太网交换机&#xff0c;紧凑机身设计节省70%机房空间&#xff0c;冗余电源和智能风扇确保系统高可用性&#xff0c;有效优化散热和降低能耗。 支持25G/40G/100G多速率自适应交换架构&#xff0c;构建超低时延企业…...