@media-direktivet i SASS
I SASS brukes @media-direktivet på samme måte som
den tilsvarende regelen i CSS. Og det kan også
legges direkte inn i alle CSS-regler.
Det skal bemerkes at når vi legger
@media-direktivet inn i en CSS-regel, etter kompilering
løftes den opp til toppen av stilarkene, og selektorene
der direktivet ble plassert flyttes inn i @media.
Basert på dette kan vi legge til regler i @media-direktivet
uten å gjenta selektorer eller forstyrre flyten i stilarket.
La oss se på et eksempel:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
La oss nå se på resultatet etter kompilering:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Det er også mulig å legge @media-spørringer
inni hverandre, og etter kompilering
slås de sammen med and-operatoren:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Dette er hva vi får etter kompilering:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
En annen egenskap ved @media-direktivet
er at det kan brukes til å overføre
variabler, funksjoner og operatorer:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
Og i filen style.css får vi følgende kode:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Forklar hva resultatet av kompilering av følgende kode vil være:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Forklar hva resultatet av kompilering av følgende kode vil være:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Forklar hva resultatet av kompilering av følgende kode vil være:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}