@media-direktivet i SASS
I SASS används direktivet @media på samma sätt som
motsvarande regel i CSS. Och det kan också
kapslas in direkt i alla CSS-regler.
Det bör noteras att när vi kapslar in
directivet @media i en CSS-regel, efter kompilering
lyfts den upp till toppen av stilmallarna, och selektorerna,
där direktivet placerades, flyttas inuti @media.
Utifrån detta kan regler läggas till i direktivet @media
utan att upprepa selektorer eller bryta mot flödet i stilmallen.
Låt oss titta på ett exempel:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Låt oss nu titta på kompileringsresultatet:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Det finns också möjlighet att kapsla @media-förfrågningar
inuti varandra, och efter kompilering
slås de ihop med operatorn and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Här är vad vi kommer att se efter kompilering:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
En annan funktion hos direktivet @media
är att det kan användas för att skicka
variabler, funktioner och operatorer:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
Och i filen style.css får vi följande kod:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Berätta vad som blir resultatet av kompilering av följande kod:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Berätta vad som blir resultatet av kompilering av följande kod:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Berätta vad som blir resultatet av kompilering av följande kod:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}