Dyrektywa @if w SASS
Jeśli potrzebujemy, aby określone
style były stosowane tylko pod warunkiem spełnienia
konkretnych warunków, używamy
dyrektywy @if, która zwraca dowolną
wartość, z wyjątkiem false i null:
Rozważmy następujący przykład:
#main-button {
@if 2 - 1 == 1 {
color: green;
}
@if (2+3) < 3 {
color: orange;
}
@if null {
color: red;
}
}
Wynik kompilacji:
#main-button {
color: green;
}
Również przy stawianiu warunku po @if
można zastosować kilka @else if
i jedno wyrażenie @else.
$var: 20px;
a {
@if $var == 10px {
color: blue;
} @else if $var == 25px {
color: red;
} @else if $var == 10px+10px {
color: green;
} @else {
color: black;
}
}
Spójrzmy teraz na plik styles.css:
a {
color: green;
}
Opowiedz, jaki będzie wynik kompilacji następującego kodu:
$size: 20px;
$font-size: 14px;
body {
@if $size == $font-size {
background-color: #7e7ed8;
} @else if $size > $font-size {
color: #f1bbbb;
} @else {
color: #000000;
}
}
Opowiedz, jaki będzie wynik kompilacji następującego kodu:
$size: 20px;
$font-size: 14px;
.active {
@if $size < $font-size {
color: red;
} @else if $size > $font-size {
color: green;
} @else {
color: #000000;
}
}
.not-active {
@if $size == $font-size {
display:block ;
} @else {
display: none;
}
}