直接用 .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是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。
相关推荐
昆曲之源_娄江河畔15 小时前
SQL2000记录行锁定阿_旭15 小时前
基于YOLO26深度学习的【咖啡果实成熟度检测与计数系统】【python源码+Pyqt5界面+数据集+训练代码】Anastasiozzzz15 小时前
万字深度实战!AI Agent 接入万物的底层密码:MCP 协议传输机制与开发指南(下篇)JAVA面经实录91715 小时前
完整版JVM 深度学习体系(一)WL_Aurora15 小时前
MySQL 目录结构全解析Languorous.15 小时前
SQL新手高频语法错误:分号遗漏、字段名写错,避坑合集灰色人生qwer15 小时前
python 中 BaseModel 在这里有什么用?AI技术控15 小时前
ReAct 论文解读:大模型 Agent 如何通过“推理 + 行动”完成复杂任务Anastasiozzzz15 小时前
深度解析 AI 时代的“TCP/IP协议”:Agent-to-Agent (A2A) 通信架构与多智能体协同底层逻辑wang3zc15 小时前
如何设置密码复杂度策略以约束MongoDB用户的密码强度