Директива @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;
}
}