BEM命名规范

BEM命名规范

本节主要学习BEM命名的基本概念,介绍了Block、Element与Modifier常用的命名规范,BEM命名规范在预处理器语言中的使用。

01-21侠课岛    初级拔高       

前端/前端/前端系列课程P2 9     0     441

(二十)BEM命名规范

1:基本概念

  • BEM 命名规范
    • Block - 更高级别的抽象或组件
    • Element - Block 的后代
    • Modifier - 不同状态
  • 命名方法
.block__element--modifier {
    display: flex;
}
.block--modifier {
    display: flex;
}
.block__element {
    display: flex;
}

<p class="header">
    <p class="header__body">
        <button class="header__button--primary"></button>
        <button class="header__button--default"></button>
    </p>
</p>
  • 清晰的描述
  • 清晰的结构

2:Block

  • 负责描述功能 - 不包含状态
/* correct */
.header {

}

/* wrong */
.header--select {

}
  • 不影响自身布局 - 不包含具体样式
/* correct */
.header {

}

/* wrong */
.header {
    margin-top: 50px;
}
  • 不使用元素选择器和ID选择器
/* correct */
.header {

}

/* wrong */
.header a {
    margin-top: 50px;
}

本教程图文或视频等内容版权归侠课岛所有,任何机构、媒体、网站或个人未经本网协议授权不得转载、转贴或以其他方式复制发布或发表。

评价

9

本课评分:
  •     非常好
难易程度:
  •     适中的

内容目录


本文索引


|
教程
粉丝
主页

签到有礼

已签到2天,连续签到7天即可领取7天全站VIP

  • 1
    +2 金币
  • 2
    +3 金币
  • 3
    +5 金币
  • 6
    +7 金币
  • 5
    +6 金币
  • 4
    暖心福利
    自选分类VIP ×1天
  • 7
    惊喜大礼

    自选分类VIP ×3天 +20金币
  • 持续签到 +8 金币

金币可以用来做什么?