SASS में @media डायरेक्टिव
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;
}
}