類似於其他的控制指令,@while指令也需要SassScript運算式和直到該語句的計算結果為假之前,它會反復輸出嵌套樣式。需要注意的關鍵一點是,在每個迭代記數變數需要遞增/遞減。
語法
while(condition) { // CSS codes }
示例
下麵的例子演示了如何使用 @while 指令:
<html> <head> <title>Control Directives & Expressions</title> <link rel="stylesheet" type="text/css" href="style.css"/> </head> <body> <p class="paddding-50">This is line one with left padding 50. </p> <p class="paddding-40">This is line two with left padding 40.</p> <p class="paddding-30">This is line three with left padding 30. </p> <p class="paddding-20">This is line four with left padding 20. </p> <p class="paddding-10">This is line five with left padding 10. </p> </body> </html>
接下來,創建檔 style.scss
style.scss
$i: 50; @while $i > 0 { .paddding-#{$i} { padding-left: 1px * $i; } $i: $i - 10; }
可以告訴SASS監視檔,並隨時使用下麵的命令更新SASS檔修改CSS:
sass --watch C:\Ruby22-x64\style.scss:style.css
接著執行上面的命令,它會自動創建 style.css 檔,下麵的代碼:
style.css
.paddding-50 { padding-left: 50px; } .paddding-40 { padding-left: 40px; } .paddding-30 { padding-left: 30px; } .paddding-20 { padding-left: 20px; } .paddding-10 { padding-left: 10px; }
輸出結果
讓我們來執行以下步驟,看看上面的代碼工作:
保存上面的 html 代碼在 @while.html 檔中。在流覽器中打開該HTML檔,得到輸出如下顯示。


上一篇:
Sass @each指令
下一篇:
Sass控制指令&運算式