BEM 是 Block(块) Element(元素) Modifier(修饰器)的简称 使用BEM规范来命名CSS,组织HTML中选择器的结构,利于CSS代码的维护,使得代码结构更清晰(弊端主要是名字会稍长)
在本规范中,以双下划线 __ 来作为块和元素的间隔,以单下划线 _ 来作为块和修饰器 或 元素和修饰器 的间隔,以中划线 - 来作为 块|元素|修饰器 名称中多个单词的间隔
保证各个部分只有一级 B__E_M ,修饰器需要和对应的块或元素一起使用,避免单独使用
<!-- 某个块 -->
<form class="search-form">
<!-- 某个元素 -->
<div class="search-form__content-left">
<!-- 错误:不能出现多个元素 -->
<h2 class="search-form__content-left__h2">标题</h2>
<!-- 某个元素,虽然是子集,保证了只有一级元素 -->
<input class="search-form__input">
<!-- 某个元素,加上了hover修饰器 -->
<button class="search-form__button search-form__button_hover">搜索</button>
<button class="search-form__button-set search-form__button-set_hover">搜索1</button>
<!-- 错误:不能单独使用lg修饰器 -->
<button class="search-form__button_lg">搜索</button>
<!-- 块中可嵌套着另一个块 -->
<p class="my-img">
<img class="my-img__logo" src="abc.png" alt="image" title="image">
</p>
</div>
</form>
<div class="search-result"></div>
在样式文件中,仅以类名作为选择器,不使用ID或标签名来约束选择器,且CSS(或者SCSS编译后的CSS)中的选择器嵌套不超过2层,增加效率和复用性,减少选择器之间的耦合度
比较常见的嵌套情景:需要通过块状态对内部元素进行调整时
.search-form {
position: relative;
}
.search-form__input {
font-size: 12px;
}
.search-form__button_hover {}
/* 避免:避免使用不必要的嵌套(此处只是简单的嵌套,没有必要) */
.search-form__content-left .search-form__input {}
/* 稍好的嵌套(此处是在块的theme1修饰器下的子元素,某些时候有必要) */
.search-form_theme1 .search-form__input {}
/* 错误:使用了标签 */
button.search-form__button {}
.search-form button {}
而在SASS文件中,也需要注意嵌套层次的意义,尽量按照 BEM三层来
/* 避免这样做 .search 不是一个独立的块 */
.search {
/* 应该把这个块提取出来 */
&-form {
&__button {
&_hover {}
/* 应该把这个元素提取出来 */
&-set {
&_hover {}
}
}
}
&-result {
}
}
/* 建议这样,按照各级区分出来 */
.search-form {
&__button {
&_hover {}
}
&_button-set {
&_hover {}
}
}
.search-result {
}
/* 对于嵌套在块中的块,如果非常有必要,可以嵌套写样式 */
.search-form {
.my-img {
&__logo {}
}
}
/* 但一般来说,不建议,因为这破坏了块的独立性。可转换成设置对应的 元素来表现,如 */
.search-form {}
.my-img {
&__search-form-logo {}
}
BEM 规范虽然结构比较清晰,但有时候会产生代码冗余。
为避免写太多重复性的代码,我们要学会善于利用预编译语言的(适当地使用 @include @extend 等)
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有