CSS如何高效命名样式类_掌握BEM规范提升语义化程度

直接用 btn-red 等视觉化命名会导致样式与外观强耦合,修改设计需改类名并牵连 HTML;多人协作时语义模糊,易误用、难维护。应以角色(如 btn-primary)而非外观命名,禁用纯状态词和单单词类名。为什么直接用 btn-red 这类名字会出问题因为样式名一旦和视觉强绑定,改个颜色或布局就不得不改类名,甚至牵连 HTML。更麻烦的是,多人协作时没人知道 card-small 是指宽度、高度还是字体大小------它没表达"谁在什么上下文中干了什么"。常见错误现象:header-blue 用在 footer 上,结果加了 !important 强行覆盖;或者重构时发现 list-inline 其实是垂直排列,但没人敢删------怕影响其他页面。命名应描述「角色」而非「外观」,比如 btn-primary 表示主操作按钮,不是"蓝色按钮"避免纯状态词(hidden、active),它们该由 JS 控制 class 切换,不写死在 CSS 里项目初期就禁用单单词类名(如 menu、item),它们几乎必然冲突BEM 的三个部分怎么拆解才不混乱BEM 是 Block--Element--Modifier 的缩写,但很多人卡在"哪个是 Block"。关键判断标准:这个模块是否能独立存在、可复用、有明确边界?比如一个搜索框(search-form)是 Block;里面的输入框(search-form__input)是 Element;带加载态的版本(search-form--loading)是 Modifier。容易踩的坑:header__logo__link 这种嵌套是错的------Element 只能直属 Block,不能套 Element。正确写法是 header__logo-link 或拆成独立 Block logo-link。立即学习"前端免费学习笔记(深入)"; HIX.AI HIX.AI是一个多功能的一体化AI写作助手,集成了120多种AI写作工具,支持50多种语言,能够满足各种写作需求。

相关推荐
兵慌码乱10 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot12 小时前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
顾林海17 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
呱呱复呱呱19 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils20 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽1 天前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码1 天前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱1 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵1 天前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学