Sass 嵌套规则和属性

Sass 嵌套规则

Sass 允许您以与 HTML 相同的方式嵌套 CSS 选择器。

请看这个网站导航的 Sass 代码实例:

SCSS 语法:

nav {
  ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }
  li {
    display: inline-block;
  }
  a {
    display: block;
    padding: 6px 12px;
    text-decoration: none;
  }
}

请注意,在 Sass 中,ullia 选择器嵌套在 nav 选择器中。

而在 CSS 中,规则是一一定义的(不是嵌套的):

CSS 语法:

nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

nav li {
  display: inline-block;
}

nav a {
  display: block;
  padding: 6px 12px;
  text-decoration: none;
}

因为您可以在 Sass 中嵌套属性,所以它比标准 CSS 更清晰、更易阅读。

Sass 嵌套属性

许多 CSS 属性有相同的前缀,例如:

  • font-family
  • font-size
  • font-weight
  • text-align
  • text-transform
  • text-overflow

通过使用 Sass,您可以将它们编写为嵌套属性:

SCSS 语法:

font: {
  family: Helvetica, sans-serif;
  size: 18px;
  weight: bold;
}

text: {
  align: center;
  transform: lowercase;
  overflow: hidden;
}

Sass 转译器会将以上代码转换为普通 CSS:

CSS 输出:

font-family: Helvetica, sans-serif;
font-size: 18px;
font-weight: bold;

text-align: center;
text-transform: lowercase;
text-overflow: hidden;