[译] 探索 SMACSS:可扩展的模块化 CSS 框架

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

内容简介:当我们在从事大项目或团队开发工作时,我们经常会发现我们写的代码,凌乱、难以阅读并且难以扩展。尤其是当一段时候后我们回头再看自己的代码,必须回想起当初自己写的时候的思路才能看懂。因此,人们创建了许多CSS 框架来对 CSS 代码进行样式化,使其更具可读性。比如说,SMACSS 的架构方法与 Bootstrap 或 Foundation 等 CSS 框架略有不同。相反,它是一组规则,更是一套模板或指南。因此,让我们来深入探究下这些 CSS 设计模式,看怎么用它们来让我们的代码更好、更整洁、更易读、更具模块化。

当我们在从事大项目或团队开发工作时,我们经常会发现我们写的代码,凌乱、难以阅读并且难以扩展。尤其是当一段时候后我们回头再看自己的代码,必须回想起当初自己写的时候的思路才能看懂。

因此,人们创建了许多CSS 框架来对 CSS 代码进行样式化,使其更具可读性。比如说, SMACSS ,即 Scalable(可扩展)Modular Architecture(模块化)CSS ,就旨在实现这一点。我采用的是 Johnathan Snook 定的那套 CSS 框架指南。

SMACSS 的架构方法与 Bootstrap 或 Foundation 等 CSS 框架略有不同。相反,它是一组规则,更是一套模板或指南。因此,让我们来深入探究下这些 CSS 设计模式,看怎么用它们来让我们的代码更好、更整洁、更易读、更具模块化。

每个 SMACSS 项目结构分为 5 种规则:

  1. Base(基础)
  2. Layout(布局)
  3. Modules(模块)
  4. State(状态)
  5. Theme(主题)

Base(基础规则)

在 SMACSS 中,基础样式定义了元素全局的默认样式。如果你用了样式重置代码,那会让你的样式表现在不同浏览器上保持一致,即便这些浏览器内部定义的默认 CSS 有所不同。

在基础规则中,你应该只包含基本元素选择器或者那些伪类选择器,不应包含类选择器或者 ID 选择器。(你应该在理由相当充分时才将类或 ID 放进去,可能也就只有一种情况了:你用了第三方插件的节点又想对特点节点的默认样式进行覆盖。)

这是一个基础规则的文件单元的例子:

html {
    margin: 0;
    font-family: sans-serif;
}

a {
    color: #000;
}

button {
    color: #ababab;
    border: 1px solid #f2f2f2;
}
复制代码

它应该包含计划在整个网站上使用的默认的大小、边距、颜色、边框和其他默认值。你的排版和表单元素应该在每个页面上具有统一的样式,给人感觉它们是统一的设计和主题。

不管你用不用 SMACSS,我都强烈建议避免使用 !important ,也不要使用深嵌套,关于为什么我会在这篇帖子的后面进行深入讨论。此外,如果你的项目使用了 CSS 重置代码,那你应该把它放在这一部分(我更喜欢使用 Sass,这样我就可以在 SASS 文件顶部方便地将重置代码引入进来,而不需要将其复制或者在每个页面的 <header> 元素单独引用)。

相关资源: Theming with Sass: An SCSS Tutorial

Layout(布局规则)

布局将会把页面分成几个主要部分 — 不是导航或折叠面板等部分,而是真正的顶级划分。

[译] 探索 SMACSS:可扩展的模块化 CSS 框架

SMACSS 布局规则包括顶部栏、侧边栏、正文、页脚等主要部分。

这些布局包括多个 CSS 模块例如 boxes、cards、unordered lists 和 galleries 等,但我会将这些模块放到下一节再详做讨论。让我们通过一个网页例子来看看怎么对页面进行布局划分:

[译] 探索 SMACSS:可扩展的模块化 CSS 框架

这些布局包含一些模块,比如顶部栏的链接和 logo,正文的盒子结构和文章,页脚的链接和版权。对于上面的布局,我们通常会设置 ID 选择器,因为他们在页面上是单独唯一的。

你还应该使用字母 l 为布局规则添加前缀,以区分其他的模块样式。通常你要设置一些和布局相关的东西,比如边框,对齐,外边距等。页面那些大布局的背景也可以考虑写进去,即使它看起来不那么像是一种布局样式。

这是一个布局规则的例子:

#header {  
    background: #fcfcfc;
}

#header .l-right {
    float: right;
}

#header .l-align-center {
    text-align: center;
}
复制代码

你也可以将上面这些 工具 样式用在对齐上,比方说你想给 header 子节点或节点文本进行对齐定位,那你只需简单地将合适的类名用在节点上。

另一个例子,你可以在布局框中使用一些默认的外边距,例如 .l-margin20px 的页边距。然后,无论您想要填充某个 container、element、card 或者 box ,只需将 l-margin 类添加到其中即可。不过你要用一些可复用的写法:

.l-full-width {
    width: 100%;
}
复制代码

不是像这样内部耦合的东西:

.l-width-25 {
    width: 25px;
}
复制代码

我想花点时间谈谈 SMACSS 中的命名规则。如果您从未在 CSS 中听说过命名空间的概念,那它基本上就是将名称添加到另一个元素的开头,以帮助区分它与其他任何元素。可我们为什么要这么做呢?

我不知道你是否遇到过下面的问题。你写 CSS 代码时发现页面上有一个标签,于是你给它加了一些样式,并命名为 .lable 类。之后你又遇到一个元素,也想将其命名为 .label 类,但样式与前面的不同。于是两个不同的东西拥有相同的名称,这就是一次命名冲突。

命名空间可帮助你解决此问题。最终,它们在同一级别上被称为相同的东西,但由于应用了不同的前缀,于是属于不同的命名空间,也就可以表示两种不同的样式

.box--label {
    color: blue;
}

.card--label {
    color: red;
}
复制代码

Module(模块规则)

正如我前面提到的,SMACSS 是页面上可重用的小代码块,是单一布局的一部分。这部分 CSS 我们想要存储到单独的文件夹中,因为我们在一个网页会有很多这样的模块代码。并且随着项目的增长,我们可以通过文件夹结构来拆分,比如说,模块/页面的结构

[译] 探索 SMACSS:可扩展的模块化 CSS 框架

于是在前面例子中,假如我们(在页面上)有一篇文章,它可以作为一个独立的模块。如何在这里构建 CSS 呢?我们应该有一个 .article 的类,它有 titletext 的子元素。因此,为了让它们保存在同一模块,我们需要在子元素上使用前缀:

.article {
    background: #f32;
}

.article--title {
    font-size: 16px;
}

.article--text {
    font-size: 12px;
}
复制代码

你一定注意到我们在模块前缀后面使用两个连字符。这是因为有时模块名称有两个单词或者它们的前缀类似 big-article 。我们需要两个连字符来描述子元素的位置。比如你可以试着比较 big-article-titlebig-article--titlebig-article--text

此外,如果特定模块占用了大部分页面,您可以将模块嵌套在模块中:

<div class="box">
    <div class="box--label">This is box label</div>
    <ul class="box--list list">
        <li class="list--li">Box list element</li>
    </ul>
</div>
复制代码

在这个简单的例子中,你可以看到 box 是一个模块 list 是在它里面的另一个模块。使用 list--lilist 模块的子项而不是 box 的。这里的关键概念是每个 CSS 规则最多有两个选择器,但在大多数情况下只有一个选择器是带前缀的。

这样,我们可以避免重复规则,并且在具有相同名称的子元素上具有额外的选择器,从而提高速度。它也有助于我们避免使用不需要的 !important 规则,这些规则是结构不合理的 CSS 项目的标志。

好的例子(注意单选择器):

.red--box {
    background: #fafcfe;
}

.red-box--list {
    color: #000;
}
复制代码

不好的例子(注意选择器内的重复和重叠):

.red .box {
    background: #fafcfe;
}

.red .box .list {
    color: #000;
}

.box ul {
    color: #fafafa;
}
复制代码

State(状态规则)

在 SMACSS 中状态规则是描述我们的模块在不同状态下显示外观的一种方式。所以说这一部分是关于交互性的:我们需要有不同的行为去描述元素的隐藏、扩展或修改。例如,jQuery 折叠面板控件就需要定义状态,来表示节点内容何时可见何时不可见。它有助于我们在特定时刻定义元素的样式。

如果状态规则与布局规则应用于同一元素上,此时我们要添加额外的规则来覆盖前面的规则(如果有的话)。状态规则优先,因为它是规则链中的最后一个规则。

与布局规则一样,我们建议在状态规则使用前缀。这有助于我们识别它们并给予它们优先权。这里我们使用 is 前缀,如 is-hiddenis-selected

<header id="header">
    <ul class="nav">
        <li class="nav--item is-selected">Contact</li>
        <li class="nav--item">About</li>
    </ul>
</header>
复制代码
.nav--item.is-selected {
    color: #fff;
}
复制代码

在这里, !important 是可以使用的,因为状态规则经常被用于 JavaScript 的修改而不是渲染时。例如,你需要一个元素在网页加载时是隐藏的,而在点击按钮时显示,但是默认类是像下面这样写的:

.box .element {
    display: none;
}
复制代码

因此如果你只是添加了下面代码:

.is-shown {
    display: block;
}
复制代码

即使你通过 JavaScript 添加了 .is-shown 之后它还是隐藏的,这是因为第一条规则是是二级深度的,将后一条规则覆盖。

因此你可以改为这样定义状态类:

.is-shown {
    display: block !important;
}
复制代码

这就是我们如何区分状态规则和布局规则,布局规则仅用于页面的初始加载。这样不仅可以达到目的,还可以保持最少选择器的优势。

Theme(主题规则)

这个应该是最显而易见的规则,因为它定义了颜色、形状、边框、阴影还有其他等等。这些大多数都是在网站上重复使用的元素。我们不必在每次使用它们的时候都重新定义它们一下,相反,我们希望定义一个独特的类然后使用时只需添加上即可。

.button-large {
    width: 60px;
    height: 60px;
}
复制代码
<button class="button-large">Like</button>
复制代码

不要将 SMACSS 主题规则和基础规则混淆,基础规则定义了默认外观,类似于重置浏览器的默认设置,而主题规则定义了一组最终外观的样式,唯一的颜色方案。

当网站具有多套样式或者需要在不同状态下使用不同主题时,主题规则非常有用,因为当用户通过页面上的某些事件例如,主题切换按钮,触发时,主题规则可以很方便地更改和切换。至少,他们将所有主题风格保存在一个地方,以便你可以轻松地更改它们并使它们保持良好的组织结构。

CSS 组织方法

我已经介绍了这个 CSS 架构思想的关键概念。如果你想了解更多,请访问SMACSS 的官方网站并进行深入的学习。

你也可以使用更高级的方法例如OOCSS 和 BEM。后者几乎包含了所有前端工作流程和技术。但是一些人会觉得 BEM 的选择器太长太重,使用起来太复杂。如果你需要更简单易懂,并容易将其纳入你的工作流程 — 以及为你和你的团队定义基本规则的东西 — SMACSS 非常适合。

这不仅让团队新成员很容易的理解以前开发者的工作,还帮助他们快速上手项目,并没有任何代码风格上的差异。 SMACSS 只是一个 CSS 框架,它完成了它所描述的工作,不多也不少。

了解基础知识

CSS 有几种不同的类型?

有三种不同的类型。内联 CSS 直接放在 HTML 元素的样式属性上。内部 CSS 位于 HTML header 内部 style 标签内。外部 CSS 是独立的文件并通过 HTML 来索引到,避免网站在不同网页内编写重复的代码。

“CSS 模板”是什么意思?

CSS 模板通常是用来定义特定的布局以便我们在不同网页甚至不同网站上使用它们。但是除了布局,它们有时也用来为特定元素例如模态框和按钮甚至它们的组合而定义的一组规则。其他一些则用来定义 HTML 元素的默认样式。

为什么 CSS 如此重要?

CSS 在现代网页中绝对是必须的。没有它,网页只是空白页面上的一堆纯文本和图片。它不仅给网页提供样式,还组织布局和提供动画效果 — 因此它对互交性也很重要。

使用 CSS 有什么优点?

一个主要的优点是将所有的样式放在一起而不是让它们分散在整个网站的每一个元素上。它为我们提供了更多的格式选项,有助于优化页面加载时间和增加代码的复用性。


以上所述就是小编给大家介绍的《[译] 探索 SMACSS:可扩展的模块化 CSS 框架》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

Pro JavaScript Techniques

Pro JavaScript Techniques

John Resig / Apress / 2006-12-13 / USD 44.99

Pro JavaScript Techniques is the ultimate JavaScript book for the modern web developer. It provides everything you need to know about modern JavaScript, and shows what JavaScript can do for your web s......一起来看看 《Pro JavaScript Techniques》 这本书的介绍吧!

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

在线图片转Base64编码工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具