首页 web前端 css教程 CSS命名规范节约Debug时间解答

CSS命名规范节约Debug时间解答

Jan 27, 2018 am 10:05 AM
css debug

本文主要和大家分享CSS 命名规范可以节约 Debug 时间的相关知识,感兴趣的朋友一起看看吧,希望能帮助到大家。Debug CSS 是一种很耗时的操作,如果有良好的命名规范可以节约很多的 Debug 时间。

 

简评: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 命名规范有三个问题要解决:

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

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

  3. 能够看出 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 类名应该如何命名

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

你将原来的代码:

<p class="siteNavigation">
</p>
登录后复制

改成了:

<p class="site-navigation">
</p>
登录后复制

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

//the Javasript code
const nav = document.querySelector('.siteNavigation')
登录后复制

这个时候 nav 将会得到 null。

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

使用 'js-*' 来命名

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

<p class="site-navigation js-site-navigation">
</p>
登录后复制

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

//the Javasript code
const nav = document.querySelector('.js-site-navigation')
登录后复制

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

相关推荐:

CSS命名规范及网站常用中英文对照表

div+css命名参考 与 CSS命名规范_html/css_WEB-ITnose

css命名规范_html/css_WEB-ITnose

以上是CSS命名规范节约Debug时间解答的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

vue中怎么用bootstrap vue中怎么用bootstrap Apr 07, 2025 pm 11:33 PM

在 Vue.js 中使用 Bootstrap 分为五个步骤:安装 Bootstrap。在 main.js 中导入 Bootstrap。直接在模板中使用 Bootstrap 组件。可选:自定义样式。可选:使用插件。

HTML,CSS和JavaScript的角色:核心职责 HTML,CSS和JavaScript的角色:核心职责 Apr 08, 2025 pm 07:05 PM

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

bootstrap怎么写分割线 bootstrap怎么写分割线 Apr 07, 2025 pm 03:12 PM

创建 Bootstrap 分割线有两种方法:使用 标签,可创建水平分割线。使用 CSS border 属性,可创建自定义样式的分割线。

了解HTML,CSS和JavaScript:初学者指南 了解HTML,CSS和JavaScript:初学者指南 Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

bootstrap怎么调整大小 bootstrap怎么调整大小 Apr 07, 2025 pm 03:18 PM

要调整 Bootstrap 中元素大小,可以使用尺寸类,具体包括:调整宽度:.col-、.w-、.mw-调整高度:.h-、.min-h-、.max-h-

bootstrap怎么设置框架 bootstrap怎么设置框架 Apr 07, 2025 pm 03:27 PM

要设置 Bootstrap 框架,需要按照以下步骤:1. 通过 CDN 引用 Bootstrap 文件;2. 下载文件并将其托管在自己的服务器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根据需要编译 Sass/Less;5. 导入定制文件(可选)。设置完成后,即可使用 Bootstrap 的网格系统、组件和样式创建响应式网站和应用程序。

bootstrap怎么插入图片 bootstrap怎么插入图片 Apr 07, 2025 pm 03:30 PM

在 Bootstrap 中插入图片有以下几种方法:直接插入图片,使用 HTML 的 img 标签。使用 Bootstrap 图像组件,可以提供响应式图片和更多样式。设置图片大小,使用 img-fluid 类可以使图片自适应。设置边框,使用 img-bordered 类。设置圆角,使用 img-rounded 类。设置阴影,使用 shadow 类。调整图片大小和位置,使用 CSS 样式。使用背景图片,使用 background-image CSS 属性。

bootstrap按钮怎么用 bootstrap按钮怎么用 Apr 07, 2025 pm 03:09 PM

如何使用 Bootstrap 按钮?引入 Bootstrap CSS创建按钮元素并添加 Bootstrap 按钮类添加按钮文本

See all articles