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多种语言,能够满足各种写作需求。
