直接用 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多种语言,能够满足各种写作需求。
相关推荐
一只fish3 分钟前
Oracle官方文档翻译《Database Concepts 26ai》第17章-内存架构比企谷八幡21 分钟前
一张表在磁盘上长什么样:Heap File 入门流星白龙23 分钟前
【MySQL高阶】11.InnoDB存储引擎Metaphor6921 小时前
使用 Python 在 Excel 中查找并高亮显示wangbing11251 小时前
SQL Server2008 R2版自动备份问题Trouvaille ~1 小时前
【Redis篇】Redis 渐进式遍历与数据库管理旦莫1 小时前
AI测试Agent的两种架构路径:谁做主控?xcLeigh1 小时前
KES数据库运维监控与故障排查实战GlobalSign数字证书1 小时前
中小企业的 SSL/TLS 证书管理,有更轻量的方案周杰伦fans1 小时前
C# 异常继承深度解析:从设计原则到 sealed 关键字的奥秘