SASS'ta @media Direktifi
SASS'ta @media direktifi, CSS'deki karşılık gelen kural ile aynı şekilde
uygulanır. Ve aynı şekilde doğrudan tüm CSS kurallarının içine
yerleştirilebilir.
Şunu belirtmek gerekir ki, @media direktifini bir CSS kuralının içine yerleştirdiğimizde, derleme sonrasında
o, stil sayfalarının üstüne çıkar ve
içinde direktif bulunan seçiciler, @media'nın içine taşınır.
Bundan dolayı, seçicileri tekrarlamadan veya stil sayfasının akışını bozmadan
kuralları @media direktifine ekleyebiliriz.
Bir örneği inceleyelim:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Şimdi derleme sonucuna bakalım:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Ayrıca, @media sorgularını birbirinin içine yerleştirme imkanı da vardır,
ve derlemeden sonra
and operatörü ile birleştirilirler:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Derleme sonrasında şunu göreceğiz:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
@media direktifinin bir başka özelliği de,
onun aracılığıyla değişkenler,
fonksiyonlar ve operatörler aktarılabilmesidir:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
Ve style.css dosyasında aşağıdaki kodu elde ederiz:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Aşağıdaki kodun derleme sonucunun ne olacağını anlatın:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Aşağıdaki kodun derleme sonucunun ne olacağını anlatın:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Aşağıdaki kodun derleme sonucunun ne olacağını anlatın:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}