Direktiva @media v SASS-u
V SASS-u se direktiva @media uporablja enako kot
ustrezno pravilo v CSS-u. Prav tako jo je mogoče
gnezditi neposredno v vsa pravila CSS.
Omeniti velja, da v primeru, ko direktivo
@media gnezdimo v CSS-pravilo, se po prevajanju
dvigne navzgor nad slogovne predloge, selektorji,
v katerih je bila direktiva nameščena, pa se premaknejo v notranjost @media.
Iz tega izhaja, da je mogoče v direktivo @media dodajati pravila
brez ponavljanja selektorjev ali kršitve toka slogovne predloge.
Oglejmo si primer:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Zdaj pa poglejmo rezultat prevajanja:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Prav tako obstaja možnost gnezditve @media poizvedb
drugo v drugo, po prevajanju
pa se povežejo z operatorjem and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
To vidimo po prevajanju:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Še ena posebnost direktive @media
je, da z njo lahko prenašamo
spremenljivke, funkcije in operatorje:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
In v datoteki style.css dobimo naslednjo kodo:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Povejte, kakšen bo rezultat prevajanja naslednje kode:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Povejte, kakšen bo rezultat prevajanja naslednje kode:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Povejte, kakšen bo rezultat prevajanja naslednje kode:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}