@media direktyva SASS'e
SASS'e @media direktyva naudojama taip pat, kaip ir
atitinkama taisyklė CSS. Be to, ją galima
įdėti tiesiogiai į visas CSS taisykles.
Reikėtų pažymėti, kad kai mes įdedame
@media direktyvą į CSS taisyklę, po kompiliavimos
ji pakeliama aukščiau stilių lentelių, o selektoriai,
kuriuose buvo patalpinta direktyva, perkeliami į @media vidų.
Iš to seka, kad galima pridėti taisykles į @media direktyvą
be selektorių kartojimo ar stilių lentelės srauto pažeidimo.
Panagrinėkime pavyzdį:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Dabar pažiūrėkime į kompiliavimo rezultatą:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Taip pat egzistuoja galimybė įdėti @media užklausas
viena į kitą, o po kompiliavimos
jos sujungiamos and operatoriumi:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Štai ką pamatysime po kompiliavimos:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Kitas @media direktyvos ypatumas
yra tai, kad su jos pagalba galima perduoti
kintamuosius, funkcijas ir operatorius:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
Ir style.css faile mes gauname tokį kodą:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Paaiškinkite, koks bus šio kodo kompiliavimo rezultatas:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Paaiškinkite, koks bus šio kodo kompiliavimo rezultatas:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Paaiškinkite, koks bus šio kodo kompiliavimo rezultatas:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}