Η οδηγία @media στο SASS
Στο SASS, η οδηγία @media εφαρμόζεται με τον ίδιο τρόπο όπως και
ο αντίστοιχος κανόνας στο CSS. Επίσης, μπορεί να
ενσωματωθεί απευθείας σε όλους τους κανόνες CSS.
Αξίζει να σημειωθεί ότι στην περίπτωση που ενσωματώνουμε
την οδηγία @media σε έναν κανόνα CSS, μετά τη μεταγλώττιση
ανεβαίνει ψηλά πάνω από τα stylesheets, και οι επιλογείς
στους οποίους τοποθετήθηκε η οδηγία μετακινούνται μέσα στην @media.
Εξαιτίας αυτού, μπορούμε να προσθέτουμε κανόνες στην οδηγία @media
χωρίς να επαναλαμβάνουμε επιλογείς ή να διακόπτουμε τη ροή του stylesheet.
Ας δούμε ένα παράδειγμα:
.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;
}
}