La direttiva @media in SASS
In SASS, la direttiva @media viene applicata allo stesso modo della
corrispondente regola in CSS. E, analogamente, può essere
nidificata direttamente in tutte le regole CSS.
Va notato che quando nidifichiamo la
direttiva @media in una regola CSS, dopo la compilazione
essa viene sollevata in alto nei fogli di stile, mentre i selettori
in cui era posizionata la direttiva vengono spostati all'interno di @media.
Ne consegue che è possibile aggiungere regole alla direttiva @media
senza ripetere i selettori o interrompere il flusso del foglio di stile.
Consideriamo un esempio:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Ora osserviamo il risultato della compilazione:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Esiste anche la possibilità di nidificare le query @media
una dentro l'altra; dopo la compilazione
esse vengono unite dall'operatore and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Ecco cosa vedremo dopo la compilazione:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Un'altra caratteristica della direttiva @media
è che può essere utilizzata per passare
variabili, funzioni e operatori:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
E nel file style.css otteniamo il seguente codice:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Spiegate quale sarà il risultato della compilazione del seguente codice:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Spiegate quale sarà il risultato della compilazione del seguente codice:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Spiegate quale sarà il risultato della compilazione del seguente codice:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}