Diretiva @media em SASS
Em SASS, a diretiva @media é aplicada da mesma forma que
a regra correspondente em CSS. E também pode ser
aninhada diretamente em todas as regras CSS.
Vale ressaltar que, quando aninhamos a
diretiva @media em uma regra CSS, após a compilação
ela é elevada para o topo das folhas de estilo, e os seletores
onde a diretiva foi colocada são movidos para dentro de @media.
Partindo disso, é possível adicionar regras à diretiva @media
sem repetir os seletores ou interromper o fluxo da folha de estilo.
Vamos considerar um exemplo:
.navbar {
width: 400px;
@media picture and (orientation: portrait) {
width: 300px;
height: auto;
}
}
Agora vamos olhar o resultado da compilação:
.navbar {
width: 400px;
}
@media picture and (orientation: portrait) {
.navbar {
width: 300px;
height: auto;
}
}
Também existe a possibilidade de aninhar consultas @media
umas dentro das outras, e após a compilação
elas são unidas pelo operador and:
@media div {
.picture {
@media (orientation: portrait) {
width: 200px;
}
}
}
Isto é o que veremos após a compilação:
@media div and (orientation: portrait) {
.picture {
width: 200px;
}
}
Outra particularidade da diretiva @media
é que com ela é possível usar
variáveis, funções e operadores:
$media: style;
$feature: -webkit-max-device;
$value: 3.0;
@media #{$media} and ($feature: $value) {
div {
color: red;
}
}
E no arquivo style.css obtemos o seguinte código:
@media style and (-webkit-max-device: 3) {
div {
color: red;
}
}
Conte qual será o resultado da compilação do seguinte código:
.active-link {
color: blue;
@media content {
font-size: 14px;
text-decoration: underline;
}
}
Conte qual será o resultado da compilação do seguinte código:
@media p {
#product-card {
@media (font-family: Arial) {
font-size: 12px;
}
}
#product-card-title {
@media (font-family: Arial) {
font-size: 14px;
font-weight: bold;
}
}
}
Conte qual será o resultado da compilação do seguinte código:
$var: link;
$font: font-size;
$size: 10px;
@media #{$var} and ($font: $size) {
.block {
color: red;
}
}