Dyrektywa @media w SASS
W SASS dyrektywa @media jest stosowana tak samo jak
odpowiednia reguła w CSS. I podobnie można ją
zagnieździć bezpośrednio we wszystkich regułach CSS.
Należy zauważyć, że w przypadku, gdy zagnieżdżamy
dyrektywę @media w regule CSS, po kompilacji
zostaje ona wyniesiona do góry nad arkusze stylów, a selektory,
w których znajdowała się dyrektywa, są przenoszone do wnętrza @media.
W związku z tym, można dodawać reguły do dyrektywy @media
bez powtarzania selektorów lub zakłócania przepływu arkusza stylów.
Rozważmy przykład:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Teraz spójrzmy na wynik kompilacji:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Istnieje również możliwość zagnieżdżania zapytań @media
jedno w drugim, a po kompilacji
są one łączone operatorem and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Oto, co zobaczymy po kompilacji:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Kolejną cechą dyrektywy @media
jest to, że za jej pomocą można przekazywać
zmienne, funkcje i operatory:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
W pliku style.css otrzymujemy następujący kod:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Opowiedz, jaki będzie wynik kompilacji następującego kodu:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Opowiedz, jaki będzie wynik kompilacji następującego kodu:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Opowiedz, jaki będzie wynik kompilacji następującego kodu:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}