Verkettete Erweiterungen mit @extend in SASS
Die Direktive @extend unterstützt auch
verkettete (sequentielle) Erweiterung, d. h.
ein Selektor kann durch einen anderen Selektor erweitert werden,
der seinerseits durch einen dritten
Selektor erweitert wird. Zum Beispiel:
Betrachten wir ein Beispiel:
.warning {
border: 1px solid;
background-color: #ffd900;
}
.personalWarning {
@extend .warning;
border-width: 3px;
}
.systemWarning {
@extend .personalWarning;
position: center;
}
Wie wir aus dem Ergebnis der Kompilierung sehen,
haben alle Elemente mit der Klasse .systemWarning
auch die Stile der Klassen .warning und
.personalWarning:
.warning, .personalWarning, .systemWarning {
border: 1px solid;
background-color: #ffd900;
}
.personalWarning, .systemWarning {
border-width: 3px;
}
.systemWarning {
position: center;
}
Erklären Sie, wie das Ergebnis der Kompilierung des folgenden Codes aussehen wird:
div {
font-size: 10px;
color: #181402;
}
.main-block {
@extend div;
border: 2px solid orange;
}
#warning-text {
@extend .main-block;
margin-top: 10px;
}
Erklären Sie, wie das Ergebnis der Kompilierung des folgenden Codes aussehen wird:
p {
padding: 10px;
}
.main-text {
font-weight: 800px;
}
.card {
@extend p;
color: #021338;
}
.product-card {
@extend .card, .main-text;
font-size: 12px;
}
Erklären Sie, wie das Ergebnis der Kompilierung des folgenden Codes aussehen wird:
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;
}