BEM规范入门

背景

经常我们在给一个大型网站写页面的css时候,经常会出现如下的css编写效果。

  .container .form .input  .warpper .icon {
        /*写入你需要的css*/
    }  

  .container .form .text  {
       /*写入你需要的css*/
  }

 .page .warpper .layout .content{
       /*写入你需要的css*/
  }

这样的css编写效果就是传统的命名空间的方式写css,它很好得解决了编写单纯全局css互相影响的问题,但是另外一方面它也引申出了一些问题:

  • 维护css的时候,只看HTML,我们无法知道当前css的作用范围,css的表现不够一目了然。
  • 如果我要覆盖css的样式,可能我就需要利用css的优先级的规则去覆盖原有的css,这样就会导致css优先级竞争
  • css编写的时候复用性不高,当存在多个样式一致的时候,我们可能会选择减少命名空间的方式来提升当前css的作用范围,但是可能会导致css样式冲突的问题。

由于我们的行业很棒,我们有很多推荐的解决方案。因为专家们的纷纷加入,于是我们有 BEM,OOCSS,SMACSS,Atomic Design 等许多选择。

CSS 规范究竟在解决什么问题

  • 我必须 立即知道编辑一个 class 是否安全,会不会干扰其他 CSS。这是最重要的,特别是当我需要在短时间内进行修改时。我不想因为改变一处而破坏别的东西。
  • 我必须立即知道一个 class 放在这个伟大工程中的什么地方,以防止大脑过载。这样我就可以快速修改 style,而不必在整个工程里前后引用。
  • class 必须 尽可能少,因为看到一长串的 class 时我头很晕。
  • 我必须 立即知道一个组件是否使用了 JavaScript,所以如果我改变了它的 CSS,我不会意外地破坏任何组件。

在我的探索中,BEM规范进入了我的视线。

什么是BEM

如果你从未接触过BEM,那么你第一次接触到BEM的时候它是长这个样子的。


.block { /* styles */ }
.block__element { /* styles */ } 
.block--modifier { /* styles */ }

期中的BEM分别对应blockelementmodifier

什么是块

在规范中,块表示一个组件的意思,这样看上去有点抽象,我们可以通过例子来学习,假设你要写一个按钮的组件。我们只需要设置了一个 .button 类的按钮,然后可以在任何

如果会scss或任何其他预处理器的mixin,我们就可以减少一些class,写成这样:

   
 
    
  
  

什么是元素

元素是块的子节点。为了表明某个东西是一个元素,你需要在块名后添加 __element。所以,如果你看到一个像那样的名字,比如 form__row ,你将立即知道 .form 块中有一个 row 元素。

BEM 元素有两个优点 :

  1. 你可以让 CSS 的优先级保持相对扁平。
  2. 你能立即知道哪些东西是一个子元素。

总结

以上就是简单的BEM规范和使用方法的简单介绍。基本的BEM规范的使用可以解决之前提到的一些问题:

  1. class 的数量必须尽可能少 ,防止了css的优先级竞争
  2. 立即知道一个 class 放在这个伟大工程中的什么地方,以防止大脑过载。

但是还有在实际应用中还有一些问题没有解决。

  1. 我必须 立即知道组件是否使用 JavaScript 。
  2. 我必须 立即知道编辑一个 class 是否安全,会不会干扰其他 CSS。

剩下的问题,我们就需要命名空间配合BEM来解决。

附录:

编写模块化CSS:BEM
编写模块化的CSS:命名空间

你可能感兴趣的:(BEM规范入门)