Direktíva @media v SASS
V SASS sa direktíva @media používa rovnako ako
príslušné pravidlo v CSS. A tiež ju možno
vnoriť priamo do všetkých pravidiel CSS.
Treba poznamenať, že v prípade, keď vkladáme
direktívu @media do CSS pravidla, po kompilácii
sa zdvihne nahor nad štýly a selektory,
v ktorých bola direktíva umiestnená, sa presunú dovnútra @media.
Z toho vyplýva, že je možné pridávať pravidlá do direktívy @media
bez opakovania selektorov alebo narušenia toku štýlov.
Pozrime sa na príklad:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Teraz sa pozrime na výsledok kompilácie:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Existuje tiež možnosť vkladať @media dopyt
jeden do druhého, a po kompilácii
sa spoja operátorom and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Tu je výsledok po kompilácii:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Ďalšou vlastnosťou direktívy @media
je to, že s jej pomocou je možné prenášať
premenné, funkcie a operátory:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
A v súbore style.css dostaneme nasledujúci kód:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Povedzte, aký bude výsledok kompilácie nasledujúceho kódu:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Povedzte, aký bude výsledok kompilácie nasledujúceho kódu:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Povedzte, aký bude výsledok kompilácie nasledujúceho kódu:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}