La directive @if dans SASS
Si nous avons besoin que des styles spécifiques
s'appliquent uniquement lorsque des conditions
précises sont remplies, nous utilisons la
directive @if, qui renvoie n'importe
quelle valeur, à l'exception de false et null :
Considérons l'exemple suivant :
#main-button {
@if 2 - 1 == 1 {
color: green;
}
@if (2+3) < 3 {
color: orange;
}
@if null {
color: red;
}
}
Résultat de la compilation :
#main-button {
color: green;
}
De plus, lors de la définition d'une condition après @if,
il est possible d'utiliser plusieurs @else if
et une expression @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;
}
}
Regardons maintenant dans le fichier styles.css :
a {
color: green;
}
Expliquez quel sera le résultat de la compilation du code suivant :
$size: 20px;
$font-size: 14px;
body {
@if $size == $font-size {
background-color: #7e7ed8;
} @else if $size > $font-size {
color: #f1bbbb;
} @else {
color: #000000;
}
}
Expliquez quel sera le résultat de la compilation du code suivant :
$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;
}
}