资讯专栏INFORMATION COLUMN

好的 CSS 命名规范可以节约 Debug 时间

wean / 2217人阅读

摘要:简评是一种很耗时的操作,如果有良好的命名规范可以节约很多的时间。一些团队使用连字符分隔符,而其他团队则倾向于使用更加结构化的称为的命名规范。一般来说,命名规范有三个问题要解决能够通过名字就能清楚选择器的功能。

简评:Debug CSS 是一种很耗时的操作,如果有良好的命名规范可以节约很多的 Debug 时间。

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

你可能习惯了在 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 code
const nav = document.querySelector(".siteNavigation")

这个时候 nav 将会得到 null。

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

使用 "js-*" 来命名

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


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

//the Javasript code
const nav = document.querySelector(".js-site-navigation")

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

英文原文: CSS Naming Conventions that Will Save You Hours of Debugging

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/115694.html

相关文章

  • 前端领域的BEM到底是什么

    摘要:在这篇译什么是我们为什么需要他们的结尾处,明确指出不需要,那么到底是什么呢下面我将把官网的教程翻译出来,带领大家搞清楚前端领域的到底是什么。命名在计算机科学领域,只有个非常难解决的问题一个是缓存失效,而另一个则是命名。 在这篇【译】什么是CSS Modules ?我们为什么需要他们?的结尾处,明确指出CSS Modules不需要BEM,那么BEM到底是什么呢? 下面我将把BEM官网的教...

    GitChat 评论0 收藏0
  • 【推荐】jquery开发的大型web应用—H5编辑器工具

    H5编辑器介绍 H5DS (HTML5 Design software) 这是一款基于WEB的 H5制作工具。让不会写代码的人也能轻松快速上手制作H5页面,界面如下 showImg(https://segmentfault.com/img/bVUC2L?w=1147&h=643); 制作流程 注册 -> 登录 -> 新建H5 -> 编辑H5 (添加页面,添加图层,拖动设置参数) -> 预览/保存/...

    keithyau 评论0 收藏0
  • 【推荐】jquery开发的大型web应用—H5编辑器工具

    H5编辑器介绍 H5DS (HTML5 Design software) 这是一款基于WEB的 H5制作工具。让不会写代码的人也能轻松快速上手制作H5页面,界面如下 showImg(https://segmentfault.com/img/bVUC2L?w=1147&h=643); 制作流程 注册 -> 登录 -> 新建H5 -> 编辑H5 (添加页面,添加图层,拖动设置参数) -> 预览/保存/...

    Gu_Yan 评论0 收藏0
  • (css/js)如何起个好名字

    摘要:就会给起名表示求和函数,渐渐地知道最好用英语给变量或者是函数名起名字,尽管有时候英语不好,那就翻翻有道吧。所以有一段时间的命名是很长的两三个单词的驼峰法命名。 什么鬼,又不知道怎么命名class了直接进入正文 记得大一学C语言的时候,那个时候根本没把这当回事吧。所谓的混沌阶段变量名,函数名,随意吧,那个时候写简单地c程序,就好像写着玩,就算复杂点得也不过一二百行,所以变量名什么的,可能...

    Rainie 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<