基础语法
#sidebar { width: 30%; background-color: #faa; }
在sass里,&表示上层选择器
.div{ width: 200px; &:hover{ background-color: greenyellow; } }
生成样式
.div { width: 200px; } .div:hover { background-color: greenyellow; }
嵌套选择器
$width:30px; $color:#456789; .div1{ width: $width; height: $width; background-color: $color; .div-inner{ width: $width; height: $width; background-color: $color; .div-inner-inner{ width:$width; height:$width; background-color: $color; } } a{ color:red; } }
生成样式
.div1 { width: 30px; height: 30px; background-color: #456789; } .div1 .div-inner { width: 30px; height: 30px; background-color: #456789; } .div1 .div-inner .div-inner-inner { width: 30px; height: 30px; background-color: #456789; } .div1 a { color: red; }
复合写法(这种写法 “:”后一定要加空格,否则语法错误)
.div1{ border: { left:1px solid #000; top: 2px solid #eee; }; background: { image:url('abc.png'); color:#000; } }
生成样式
.div1 { border-left: 1px solid #000; border-top: 2px solid #eee; background-image: url("abc.png"); background-color: #000; }
sass数据的常见类型
number类型
$width:300px; $zoomValue:2; .div{ width:$width: height:$width; zoom:$zoomValue; }
color类型
$color:red: $colorHex:#ffe932; .div{ color:$color; background-color:$colorHex; }
String类型
$str:'hello.jpeg'; .div{ background-image:url('images/'+$str); }
list类型(sass里的数组类型)
$list: (100px,200px,'string',2);
注意:在sass里,数组的下标从1开始
使用list
获取子元素
.div { width:nth($list, 1); height:nth($list, 2); }
获得子元素在数组中的下标
.div{ zoom:index($list,'string'); }
map类型(sass里的对象类型)
$map:(top:1pxs,left:2px,bottom:3px,right:4px);
循环遍历每个值
.div{ @each $key, $value in $map { #{$key}:$value; } }
sass基本运算
加减乘除
( )代表运算
$num1:100px; $num2:200px; $width:$num1+$num2; .div{ width:$width; } .div{ font:(10px/8); font:(10px*8); width:$width/2; margin-left:(5px+8px/2); }
颜色运算
$color1:#010203; $color2:#040506; $color3:#a69e61; .div{ color:mix($color1,$color2); color:red($color1); color:red($color3); color:green($color3); color:blue($color3); color:rgb(red($color3),green($color3),blue($color3)); }
Mixin(代码块)
一般mixin
@mixin helloMixin{ display: inline-block; font:{ size:20px; weight:500; } color:red; } .div{ @include helloMixin; }
嵌套mixin
@mixin helloMixin2{ padding:10px; @include helloMixin; background-color: red; } .div { width: 100px; @include helloMixin2; }
参数mixin
@mixin sexy-border(#color,$width){ border:{ color: $color; width: $width; style:dashed; }; } .div{ @include sexy-border(blue,2px); }
sass继承
简单继承
.div{ border:1px; background-color: red; } .div{ @extend .div; border-width: 3px; }
生成样式
.div { border: 1px; background-color: red; } .div { border-width: 3px; }
关联属性继承
.div1{ border: 1px; background-color: red; } .div1.other{ background-image: url('hello.jpeg'); } .divext{ @extend .div1; }
生成样式
.div1, .divext { border: 1px; background-color: red; } .div1.other, .other.divext { background-image: url("hello.jpeg"); }
链式继承
.div1{ border: 1px solid #000; } .div2{ @extend .div1; color: red; } .div3{ @extend .div2; color: #000; }
生成样式
.div1, .div2, .div3 { border: 1px solid #000; } .div2, .div3 { color: red; } .div3 { color: #000; }
伪类继承
a:hover{ text-decoration: underline; } .hoverlink{ color: red; @extend :hover; }
生成样式
a:hover, a.hoverlink { text-decoration: underline; } .hoverlink { color: red; }
sass条件控制
if条件语句
$type: 'tony'; p{ @if $type == 'bufy' { color: red; } @else if $type == 'tim' { color: blue; } @else if $type == 'tony' { color: green; } @else { color: black; } }
生成
p { color: green; }
$type: 'tony'; p{ @if $type == 'bufy' { .div{ color: red; } } @else { .div{ color: black; } } }
生成样式
p .div { color: black; }
for条件语句
from through
@for $i from 1 through 3 { .item#{$i} { width: 1px * $i; } }
生成样式
.item1 { width: 1px; } .item2 { width: 2px; } .item3 { width: 3px; }
from to
@for $i from 1 to 3 { .item#{$i} { width: 1px * $i; } }
生成样式
.item1 { width: 1px; } .item2 { width: 2px; }
for list
$list:(1,2,3,4,5); @for $i from 1 through length($list) { .item#{$i} { width: 1px * $i; } }
生成样式
.item1 { width: 1px; } .item2 { width: 2px; } .item3 { width: 3px; } .item4 { width: 4px; } .item5 { width: 5px; }
while
$i: 6; @while $i > 0 { .item#{$i} { width: 1px * $i; } $i: $i - 2; }
生成样式
.item6 { width: 6px; } .item4 { width: 4px; } .item2 { width: 2px; }
each
$map:(top:1px,left:2px,bottom:3px,right:4px); .div{ @each $key , $value in $map { #{$key}:$value; } }
生成样式
.div { top: 1px; left: 2px; bottom: 3px; right: 4px; }