Die @media-Direktive in SASS
In SASS wird die Direktive @media genauso angewendet wie
die entsprechende Regel in CSS. Ebenso kann sie
direktiv in alle CSS-Regeln verschachtelt werden.
Es ist anzumerken, dass im Fall, wenn wir die
Direktive @media in eine CSS-Regel verschachteln, sie nach der Kompilierung
nach oben über die Stylesheets gehoben wird, und die Selektoren,
in denen die Direktive platziert war, werden in @media verschoben.
Daraus folgend, können Regeln der Direktive @media
hinzugefügt werden, ohne Selektoren zu wiederholen oder den Fluss des Stylesheets zu stören.
Betrachten wir ein Beispiel:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Nun betrachten wir das Ergebnis der Kompilierung:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Es besteht auch die Möglichkeit, @media-Anfragen
ineinander zu verschachteln, und nach der Kompilierung
werden sie mit dem Operator and verbunden:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Hier ist, was wir nach der Kompilierung sehen werden:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Eine weitere Besonderheit der Direktive @media
ist, dass mit ihrer Hilfe
Variablen, Funktionen und Operatoren übergeben werden können:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
Und in der Datei style.css erhalten wir den folgenden Code:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Erzählen Sie, wie das Ergebnis der Kompilierung des folgenden Codes aussehen wird:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Erzählen Sie, wie das Ergebnis der Kompilierung des folgenden Codes aussehen wird:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Erzählen Sie, wie das Ergebnis der Kompilierung des folgenden Codes aussehen wird:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}