Sass 控制命令:@if,@for,@each 和@while
Sass 的控制命令是创建库和重复使用代码库的一个基础,使用好 Sass,需要掌握好 Sass 的控制命令,只有掌握了这些,你才能进入 Sass 的下一个层次的学习。
Sass 控制命令的速成
Sass 控制命令可以让你在编写@mixin
和@function
时提供相应的流程和逻辑判断。
在这篇文章中我们将覆盖:@if
,@for
,@each
和@while
。
使用守则
如果你想跟着这篇文章学习 Sass 控制命令,你可以先从Github下载相应的示例代码。
为了更好的帮助大家理解,我将示例中的 Sass 语法格式更换成 SCSS 格式。——@大漠
@if
@if
指令是一个SassScript,它可以根据条件来处理样式块,如果条件为true
返回一个样式块,反之false
返回另一个样式块。
这里有一个@if
指令的简单示例,我已经对示例做了简化处理,只适合阅读,并不太实用。
1 | $boolean: true !default; |
编译出来的 CSS:
1 | .some-selector { |
还要注意在每个选项中都加了一个@debug
信息。在这篇文章中并不详细介绍@debug
,但是我添加了,主要是在命令行中输出时可以看到提示信息,让用户了解某些事情。在一些复杂的@mixin
或@function
中使用@warn
或@debug
,可以起到一定的作用,可以让程序员更容易的发现和追查问题,也更好的提供用户体验。
正如上面的示例,我们在终端编译之后,可以看到@degbug
中的对应相关信息:
1 | >>> Change detected to: test.scss |
@for
@for
指令有两种形式。
第一种形式是:
1 | @for $var from <start> through <end> |
从<start>
开始循环,到<end>
结束,非常简单明了。来看一个简单的示例:
1 | $class-slug: for !default; |
编译出来的 CSS
1 | .for-1 { |
从示例中我们可以明确的知道,从<start>
开始(此处示例是 1),一直遍历到<end>
(此处示例是 4)。包括<end>
的值。
第二种形式是:
1 | @for $var from <start> to <end> |
循环从<start>
开始,一直遍历循环到<end>
结束。这种形式的循环只要碰到<end>
就会停止循环(将不会遍历<end>
值)。我们来看一个示例:
1 | $class-slug: for !default; |
编译出来的 CSS
1 | .for-1 { |
@for
循环指令除了可以从小数值到大数值循环之外,还可以从大数值循环到小数值。而且两种形式都支持。
1 | $class-slug: for !default; |
编译出 CSS
1 | .for-5 { |
在两种形式之下,$var
都可以是任意的变量名。在通常的习惯中,一般都将$var
命名为$i
来做变量名,用于@for
指令的递增或递减。
如果你真想看看@for
指令的真实示例,你可以看看通过他创建的一个网格系统。你可以在网格系统项目的第 37-53 行看到@for
的使用。
你可以在文件中看到下面这样的代码样本:
1 | // Loops to enumerate the classes |
@each
@each
指令形式:
1 | @each $var in <list> |
如果你没有接触过列表,也不要紧,他也非常简单,就是把 2 变成 1。
在下面的例子中你可以看到,$var
就是一个变量名,<list>
是一个 SassScript 表达式,他将返回一个列表值。变量$var
会在列表中做遍历,并且遍历出与$var
对应的样式块。
这有一个@each
指令的简单示例:
1 | $list: adam john wynn mason kuroir; |
编译出 CSS:
1 | .author-bio .photo-adam { |
@while
@whild
指令也需要 SassScript 表达式(像其他指令一样),并且会生成不同的样式块,直到表达式值为false
时停止循环。这个和@for
指令很相似,只要@while
后面的条件为true
就会执行。
这里有一个@while
指令的简单用例:
1 | $types: 4; |
编译出 CSS:
1 | .while-4 { |
结论
正如你所看到的,Sass 指令可以在你的@mixin
或者@function
中添加循环遍历,条件判断功能,这样可以帮助你创建一个真正强大的库。