- sass使用$符號來聲明變量
$nav-color: #F90;
nav {
$width: 100px;
width: $width;
color: $nav-color;
}
//編譯后
nav {
width: 100px;
color: #F90;
}
- 嵌套css規則
#content {
article {
h1 { color: #333 }
p { margin-bottom: 1.4em }
}
aside { background-color: #EEE }
}
/* 編譯后 */
#content article h1 { color: #333 }
#content article p { margin-bottom: 1.4em }
#content aside { background-color: #EEE }
- 父選擇器的標識符&
article a {
color: blue;
&:hover { color: red }
}
// 編譯后
article a { color: blue }
article a:hover { color: red }
- 群組選擇器的嵌套
.container {
h1, h2, h3 {margin-bottom: .8em}
}
// 編譯后
.container h1, .container h2, .container h3 { margin-bottom: .8em }
- 嵌套屬性
nav {
border: {
style: solid;
width: 1px;
color: #ccc;
}
}
// 編譯后
nav {
border-style: solid;
border-width: 1px;
border-color: #ccc;
}
6.子組合選擇器和同層組合選擇器:>、+和~
article section { margin: 5px } // article下的所有命中section選擇器的元素(包括子代、孫代等等)
article > section { border: 1px solid #ccc } // 選擇article下緊跟著的子元素中命中section選擇器的元素(只包括子代)
header + p { font-size: 1.1em } // header元素后緊跟的p元素(同一層級)
article ~ article { border-top: 1px dashed #ccc } // article后的所有同層article元素,不管它們之間隔了多少其他元素
- 混合器
// @mixin 名字 給這組樣式命名
@mixin rounded-corners {
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
border-radius: 5px;
}
// @include 名字 引用該樣式
notice {
background-color: green;
border: 2px solid #00aa00;
@include rounded-corners;
}
//sass最終生成:
.notice {
background-color: green;
border: 2px solid #00aa00;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
border-radius: 5px;
}
- 混合器傳參
@mixin link-colors($normal, $hover, $visited) {
color: $normal;
&:hover { color: $hover; }
&:visited { color: $visited; }
}
// 當混合器被@include時,你可以把它當作一個css函數來傳參。
a {
@include link-colors(blue, red, green);
}
//Sass最終生成的是:
a { color: blue; }
a:hover { color: red; }
a:visited { color: green; }
- 選擇器繼承
// @extend 通過選擇器繼承繼承樣式
.error {
border: 1px solid red;
background-color: #fdd;
}
.seriousError {
@extend .error;
border-width: 3px;
}
// 相當于class="seriousError error"
浙公網安備 33010602011771號