Extensions en chaîne dans @extend en SASS
La directive @extend prend également en charge
l'extension en chaîne (séquentielle), c'est-à-dire
qu'un sélecteur peut étendre un autre sélecteur,
qui, à son tour, étend un troisième
sélecteur. Par exemple :
Considérons l'exemple :
.warning {
border: 1px solid;
background-color: #ffd900;
}
.personalWarning {
@extend .warning;
border-width: 3px;
}
.systemWarning {
@extend .personalWarning;
position: center;
}
Comme nous pouvons le voir d'après le résultat de la compilation,
tous les éléments avec la classe .systemWarning
ont également les styles des classes .warning et
.personalWarning :
.warning, .personalWarning, .systemWarning {
border: 1px solid;
background-color: #ffd900;
}
.personalWarning, .systemWarning {
border-width: 3px;
}
.systemWarning {
position: center;
}
Expliquez quel sera le résultat de la compilation du code suivant :
div {
font-size: 10px;
color: #181402;
}
.main-block {
@extend div;
border: 2px solid orange;
}
#warning-text {
@extend .main-block;
margin-top: 10px;
}
Expliquez quel sera le résultat de la compilation du code suivant :
p {
padding: 10px;
}
.main-text {
font-weight: 800px;
}
.card {
@extend p;
color: #021338;
}
.product-card {
@extend .card, .main-text;
font-size: 12px;
}
Expliquez quel sera le résultat de la compilation du code suivant :
p {
padding: 5px;
}
.main-text {
@extend p;
font-size: 14px;
}
.card {
@extend .main-text;
border: 1px solid black;
}
.product-card {
@extend .card;
background-color: #e1f1f1;
}