装饰性背景图在BEM中必须绑定到具体语义Block(如section-hero),禁止孤立类名;多层叠加时background-image、size、position三组属性须严格一一对应;伪元素装饰需保留语义类名;路径404会导致整条声明静默失效。
装饰性背景图在 BEM 中不是“加个 class 就完事”,而是必须明确它属于哪个语义块、是否可复用、是否需要状态控制——否则很快会变成一堆孤立的 .bg-pattern、.deco-1,改一次设计就得全局搜替换。
常见错误是写一个通用类 .deco-bg,然后到处 class="deco-bg"。这违反 BEM 的作用域原则:装饰图不是独立组件,而是某个业务模块的视觉表达部分。
section-hero、card-feature、footer-ornament
.section-hero { background-image: url('hero-deco.svg'); }
--deco 或 --pattern,它们没说明“谁在用”“为什么用”比如 .section-hero 要叠加纹理 + 渐变 + 图标,声明必须是:
.section-hero { background-image: url('icon.svg'), url('texture.png'), linear-gradient(135deg, #f0f0f0, #e0e0e0); background-size: 48px 48px, auto, 100% 100%; background-position: top right, center, center; background-repeat: no-repeat, repeat, no-repeat;}
三个值的数量、顺序、语义必须一一对应。漏掉一个 background-size,整条 background-image 就被浏览器丢弃,回退为透明。
立即学习“前端免费学习笔记(深入)”;
.section-hero--dark)若修改背景,必须重写全部三组属性,不能只覆盖 background-image
background-position: top left),否则后加载的会覆盖前一个background-image 只显示一行值,说明某一层语法出错或路径 404BEM 修饰符(如 --mobile-deco)不能替代媒体查询做分辨率适配——类名不会随 DPR 或 viewport 自动增删,也不会触发新资源请求。
@media (-webkit-min-device-pixel-ratio: 2) 覆盖 background-image,并显式设 background-size: contain 或 cover
background-size,可能被拉伸模糊;普通图设了反而会裁剪.section-hero--promo 对应 promo-deco.svg,--feature 对应 feature-deco.svg,而非 --retina
有些装饰图用 ::before 实现(比如角标、分隔线),DOM 里没有真实节点,但仍需语义锚点。
section-hero__deco 类名在容器上,哪怕只是个空 div 或伪元素载体.section-hero__deco::before { content: ''; background-image: url('corner.svg'); }
<div class="section-hero__deco"></div>,又用伪元素画同一类装饰,维护成本翻倍最常被忽略的一点:装饰图路径 404 不报错,但会导致整条 background-image 失效——它不像 <img src> 有 fallback 机制,浏览器静默丢弃整个声明。上线前务必检查所有 url() 路径是否真实存在且大小写一致。