直接用 .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是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。
相关推荐
KivenMitnick2 小时前
CialloVOL 1.2:便捷好用的轻量化内存取证分析平台九思十安2 小时前
HNU2026-计算机系统-笔记 3 HelloWorldoscar9992 小时前
OpenCode终端界面他是龙5512 小时前
70:Python安全 & SSTI模板注入 & Jinja2引擎 & 利用绕过 & 工具实战m0_676544382 小时前
MySQL数据库迁移后如何测试数据可读性_进行简单查询验证.txtweixin_458580122 小时前
C#怎么实现定时任务 C#如何用Timer和Quartz.NET创建定时执行的后台任务【技巧】果汁华2 小时前
Claude Agent SDK Python:构建自主 AI 代理的官方引擎User_芊芊君子2 小时前
从零入门!MySQL 约束、范式设计与联合查询核心精讲alwaysrun2 小时前
Python获取Steam平台安装游戏信息