De @media directive in SASS
In SASS wordt de directive @media op dezelfde manier toegepast als
de overeenkomstige regel in CSS. En ook kan deze
direct in alle CSS-regels worden genest.
Het is vermeldenswaard dat wanneer we de
directive @media in een CSS-regel nesten, deze na compilatie
naar boven wordt gebracht in de stijlbladen, en de selectors
waarin de directive was geplaatst, worden verplaatst naar binnen in @media.
Hieruit volgt dat we regels aan de directive @media kunnen toevoegen
zonder selectors te herhalen of de stroom van het stijlblad te verstoren.
Laten we een voorbeeld bekijken:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Laten we nu het resultaat van de compilatie bekijken:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Het is ook mogelijk om @media queries
in elkaar te nesten, en na compilatie
worden ze samengevoegd met de operator and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Dit is wat we na compilatie zullen zien:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Een ander kenmerk van de directive @media
is dat het ermee mogelijk is om
variabelen, functies en operatoren door te geven:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
En in het bestand style.css krijgen we de volgende code:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Vertel wat het resultaat van de compilatie van de volgende code zal zijn:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Vertel wat het resultaat van de compilatie van de volgende code zal zijn:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Vertel wat het resultaat van de compilatie van de volgende code zal zijn:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}