css BEM书写规范

栏目: CSS · 发布时间: 7年前

内容简介:BEM是基于组件的web开发方法。其思想是将用户界面分隔为独立的块,从而使开发复杂的UI界面变得更简单和快,且不需要粘贴复制便可复用现有代码。 BEM由Block、Element、Modifier组成。 选择器里用以下连接符扩展他们的关系:示例: block-name_modifier-name block-name__element-name--modifier-name block-name_modifier-name--modifier-value block-name__element-name-

BEM是基于组件的web开发方法。其思想是将用户界面分隔为独立的块,从而使开发复杂的UI界面变得更简单和快,且不需要粘贴复制便可复用现有代码。 BEM由Block、Element、Modifier组成。 选择器里用以下连接符扩展他们的关系:

  • `__:双下划线用来连接块和块的子元素
  • ` :仅作为连字符使用,连接块或元素或修饰符的多个单词(也可以直接写成驼峰式)
  • --:双中划线用来连接块或元素的状态(也可使用‘_’单下划线表示)

示例: block-name_modifier-name block-name__element-name--modifier-name block-name_modifier-name--modifier-value block-name__element-name--modifier-name--modifier-value

基本概念

Block(块)

代码片段可能被复用且这段代码不依赖其他组件即可用Block。块可以互相嵌套,可以嵌套任意多层。

特点:

  1. 块的名称用于描述它的目的。如 menu、button
  2. 块不能影响所在环境。这意味着 不能为块设置margin或position
  3. 只能使用class命名选择器,而不能使用标签或id选择器
  4. 不依赖于页面内其他块或元素

Element(元素)

Element是Block的一部分,没有独立存在的意义。任何一个Element语义上是和Block绑定的。

特点:

  1. 与块使用'__'连接。 如: block__item
  2. 用于描述它的目的。如:item、text
  3. 元素可以彼此嵌套,可以嵌套任意多层
  4. 元素总是属于块的一部分。所以类似于block__item1__item2的命名是不合法的

Modifier(修饰符)

Modifier是Block或Element上的标记。使用它们来改变样式,行为或状态。 与块或元素连接符为'--'。

应用

相对另外的Blocks定位Block

最好的方式是混合使用block和element。解决block上不能设置margin、position。 例:

<body class="page">
    <!-- header and navigation-->
    <header class="header page__header">...</header>

    <!-- footer -->
    <footer class="footer page__footer">...</footer>
</body>
复制代码
.page__header {
    padding: 20px;
}

.page__footer {
    padding: 50px;
}
复制代码

Block内定位Elements

通过额外创建Block的子Element来定位嵌套。 例:

<body class="page">
    <div class="page__inner">
      <!-- header and navigation-->
      <header class="header">...</header>

      <!-- footer -->
      <footer class="footer">...</footer>
    </div>
</body>
复制代码
.page__inner {
    margin-right: auto;
    margin-left: auto;
    width: 960px;
}
复制代码

关于命名

选择器的命名必须完整且精确地描述它代表的BEM实体。 例:

.button {}
.button__icon {}
.button__text {}
.button_theme_islands {}
复制代码

我们可直接指导我们在处理一个块元素。在html使用如:

<button class="button button_theme_islands">
    <span class="button__icon"></span>

    <span class="button__text">...</span>
</button>
复制代码

而下面的css就很难让我们做出相同的判断:

.button {}
.icon {}
.text {}
.theme_islands {}
复制代码

在我的git项目miniui中采用了BEM规范,使用sass实现了BEM。有兴趣可以查看: github.com/banyaner/mi…

参考:en.bem.info


以上所述就是小编给大家介绍的《css BEM书写规范》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Mastering Regular Expressions, Second Edition

Mastering Regular Expressions, Second Edition

Jeffrey E F Friedl / O'Reilly Media / 2002-07-15 / USD 39.95

Regular expressions are an extremely powerful tool for manipulating text and data. They have spread like wildfire in recent years, now offered as standard features in Perl, Java, VB.NET and C# (and an......一起来看看 《Mastering Regular Expressions, Second Edition》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器