Αλυσιδωτές επεκτάσεις στο @extend στο SASS
Η οδηγία @extend υποστηρίζει επίσης
αλυσιδωτή (διαδοχική) επέκταση, δηλαδή
ένας επιλογέας μπορεί να επεκταθεί από έναν άλλο επιλογέα,
ο οποίος, με τη σειρά του, επεκτείνεται από έναν τρίτο
επιλογέα. Για παράδειγμα:
Ας εξετάσουμε ένα παράδειγμα:
.warning {
border: 1px solid;
background-color: #ffd900;
}
.personalWarning {
@extend .warning;
border-width: 3px;
}
.systemWarning {
@extend .personalWarning;
position: center;
}
Όπως βλέπουμε από το αποτέλεσμα της μεταγλώττισης
όλα τα στοιχεία με την κλάση .systemWarning
έχουν επίσης τα στυλ των κλάσεων .warning και
.personalWarning:
.warning, .personalWarning, .systemWarning {
border: 1px solid;
background-color: #ffd900;
}
.personalWarning, .systemWarning {
border-width: 3px;
}
.systemWarning {
position: center;
}
Πείτε μας ποιο θα είναι το αποτέλεσμα της μεταγλώττισης του ακόλουθου κώδικα:
div {
font-size: 10px;
color: #181402;
}
.main-block {
@extend div;
border: 2px solid orange;
}
#warning-text {
@extend .main-block;
margin-top: 10px;
}
Πείτε μας ποιο θα είναι το αποτέλεσμα της μεταγλώττισης του ακόλουθου κώδικα:
p {
padding: 10px;
}
.main-text {
font-weight: 800px;
}
.card {
@extend p;
color: #021338;
}
.product-card {
@extend .card, .main-text;
font-size: 12px;
}
Πείτε μας ποιο θα είναι το αποτέλεσμα της μεταγλώττισης του ακόλουθου κώδικα:
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;
}