直接用 .header 或 .btn 会埋坑,因其未体现组件归属、层级与状态,导致协作中不敢修改、滥用 !important;应采用 BEM 三段式命名,如 .user-profile__btn--disabled,明确 Block、Element、Modifier 职责。为什么直接用 .header 或 .btn 会埋坑因为这些名字不说明"它在哪儿、属于谁、什么状态",团队协作时,没人敢轻易改。比如一个 .btn 在登录页是蓝色,在弹窗里却是红色,但样式表里找不到上下文,最后只能加 !important 硬盖,越盖越乱。真正的问题不是命名不够"高级",而是没把组件的层级关系和功能边界写进类名里。避免孤立命名:不写 .card,而写 .user-profile__card ------ 明确这是用户资料模块下的卡片状态必须显式表达:禁用按钮不是 .btn--disabled,而是 .user-profile__btn--disabled,防止跨模块误复用修饰符(Modifier)只用于变体,不用于布局定位:用 .user-profile__avatar--large 可以,但不用 .user-profile__avatar--top-left(那是布局职责,该交给 margin 或 grid-area)BEM 的三段式怎么拆解才不僵硬BEM 是 Block__Element--Modifier,但很多人卡在"哪个算 Block"------其实 Block 就是能独立存在、有明确语义的最小可复用单元,比如 search-form、product-list,而不是页面级的 homepage。Block:名词,首字母小写,中划线分隔,如 nav-menu、price-tagElement:必须依附于 Block,用双下划线连接,如 nav-menu__item、price-tag__currency;不能嵌套,nav-menu__item__icon 是错的Modifier:用双短横,只描述状态或外观变体,如 nav-menu__item--active、price-tag--on-sale;不写 --mobile 这类设备相关修饰符(响应式该用媒体查询)示例:一个带图标的搜索框立即学习"前端免费学习笔记(深入)";.search-input { /* Block 样式 */}.search-input__field { /* Element,输入框本身 */}.search-input__icon { /* Element,图标容器 */}.search-input--compact { /* Modifier,紧凑模式 */}遇到嵌套组件时,BEM 怎么避免类名爆炸真实项目里常有 user-card 里嵌 avatar 和 stats-bar,如果都按 BEM 展开,类名会变成 user-card__avatar__img ------ 这违反了 BEM 原则,也失去语义。 Tellers AI Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。
相关推荐
Esaka_Forever2 分钟前
PyCharm 社区版无法识别 .db 文件类型yyuuuzz3 分钟前
AI模型部署中的常见稳定性问题li星野4 分钟前
从零搭建带数据库的文件上传系统:FastAPI + Streamlit + SQLite+加上日志J-Tony1110 分钟前
【JVM】JIT编译器程序猿乐锅19 分钟前
【MySQL | 第七篇】 索引使用规则C137的本贾尼27 分钟前
崩溃恢复揭秘:从 Redo Log 到数据一致性Lyyaoo.27 分钟前
【MySQL】锁机制文中金域33 分钟前
备份sqlite数据库吴声子夜歌35 分钟前
JVM——原子操作类实现原理摇滚侠35 分钟前
Maven 入门+高深 SSM 案例 111-112