Дырэктыва @media у SASS
У SASS дырэктыва @media ужываецца таксама як і
адпаведнае правіла ў CSS. І таксама яе можна
ўкласці непасрэдна ва ўсе правілы CSS.
Следу адзначыць, што ў выпадку, калі мы ўкладваем
дырэктыву @media у CSS-правіла, пасля кампіляцыі
яна падымаецца ўверх над табліцамі стыляў, а селектары,
у якіх размяшчалася дырэктыва перамяшчаюцца ўнутр @media.
Ісходзячы з гэтага, можна дадаваць правілы ў дырэктыву @media
без паўтарэння селектараў або парушэння патоку табліцы стыляў.
Разгледзім прыклад:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Цяпер паглядзім на вынік кампіляцыі:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Таксама існуе магчымасць укладаць @media запыты
адзін у аднаго, а пасля кампіляцыі
яны злучаюцца аператарам and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Вось што мы ўбачым пасля кампіляцыі:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Яшчэ адной асаблівасцю дырэктывы @media
з'яўляецца тое, што з яе дапамогай можна перадаваць
зменныя, функцыі і аператары:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
І ў файле style.css мы атрымліваем наступны код:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Раскажыце, якім будзе вынік кампіляцыі наступнага кода:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Раскажыце, якім будзе вынік кампіляцыі наступнага кода:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Раскажыце, якім будзе вынік кампіляцыі наступнага кода:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}