BEM:css的命名规范

使用连字符('-')分隔字符串

你可能习惯了在 Javascript 中使用小驼峰的命名方式:

var redBox=document.getElementById('...')

但是在 CSS 中不建议使用这种命名方式:

.redBox{border:1px纯红色;}

而应该使用这种:

.red-box{border:1px纯红色;}

这是一个标准的 CSS 命名规则,有更好的可读性。

此外,他和 CSS 属性名称一致。

//正确.some-class{font-weight:10em}//错了.some-class{fontWeight:10em}

BEM 命名规范

团队有不同的方法来编写 CSS 选择器。一些团队使用连字符分隔符,而其他团队则倾向于使用更加结构化的称为 BEM 的命名规范。

一般来说,CSS 命名规范有三个问题要解决:

能够通过名字就能清楚选择器的功能。

能够看出选择器在哪里可以使用。

能够看出 class 之间的关系。

你有没有见过这样写的类名:

.nav--secondary{...}.nav__header{...}

这就是 BEM 命名规则。

B 代表块(Block)

BEM 试图将整个用户界面分成可重用独立的块(Block,注意这里的 Block 并非指 inline-block),一个 header 是一个 block,header 里面嵌套的元素(logo、input、menu)也可以是 block 。

举个例子下面的图片:

这是一个火柴人(我们可以把它看做一个 Block),按照之前的说法,这个组件的命名我们可以设为 stick-man

主键的样式应该如下所示:

.stick-man{}

E 代表元素

Block 中一般会有多个元素,举个例子:火柴人有一个 head,两个 arms 和 feets

head、feet、和 arms 是该组件中的所有元素。使用 BEM 命名规则,通过双下划线连接块(Block)和元素(Elements)方式来命名。

.stick-man__head{}.stick-man__arms{}.stick-man__feet{}

M 代表修饰符

BEM 中 M 代表修饰,可以对块(Block)或元素(Element)进行修饰(外观或行为的调整),我们可以调整我们的火柴人生成蓝色火柴人和红色火柴人(实际上我们可能需要一个蓝色按钮和一个红色按钮)。

使用 BEM 的命名规则我们使用双连接符来命名('--')

例如:

.stick-man--blue{}.stick-man--red{}

修饰符也可用于元素(element),例如我们只想调整火柴人的头部大小。我们可以这样命名

.stick-man__head--small{}.stick-man__head--big{}

以上就是 BEM 的命名方式,这种命名方式虽然有点啰嗦但是在复杂的工程中可以很好的理清各部分之间的关系,如果只是简单的工程直接使用分隔符命名就行了。

在 JavaScript 中用到的 CSS 类名应该如何命名

当你看到这个篇文章开始着手重构自己的项目。

你将原来的代码:

改成了:

这看着很棒,但是你忘了你在某个地方(JavaScript)用到了这个类名:

//the Javasript codeconst nav = document.querySelector('.siteNavigation')

这个时候 nav 将会得到 null。

为了防止这种情况,我们可以使用如下的命名来提醒我们。

使用 'js-*' 来命名

我们可以使用 js- 来命名我们的类:

在 JavaScript 代码我们使用 js-site-navigation 来获取该 DOM:

//the Javasript codeconst nav = document.querySelector('.js-site-navigation')

现在只要一看到 js-site-navigation 就会想到,在某个 JavaScript 代码中使用该类名获取 DOM 对象。  

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文 命名约定 若是使用 BEM 实体,就需要了解它的命名规则。 命名约定的理念就是使得 CSS 选择器的命名尽可...
    Jadyn阅读 7,895评论 0 0
  • 避免以视觉效果来命名类 尽量避免以类的视觉效果来命名:如.half。因为如果使用响应式布局,你的页面会有多种布局来...
    csRyan阅读 9,580评论 1 10
  • 连续考了三天试从考场出来的时候整个人都是懵的,毕竟大学里许多考试的复习期都只有考试前一天晚上,所以几乎已经熬了三个...
    我是隐形的阅读 4,406评论 7 27
  • 多少人 有哪些时刻 像这小船一样 独自在暗夜里前行 这暗夜 静谧与孤独里 涌动着不安 也有沉默而平静的自由 一枕昼...
    尘里微光阅读 2,895评论 0 5
  • “欲望从一开始就存在。有欲望,即为存在,或者说存在,即为有欲望。” “欲望的眩晕” 是一本有趣的书。作者通过电影去...
    水母elsa阅读 4,385评论 0 1