Aninhamento de seletores

Torne-se front-end com este curso 100% prático

Entender como funciona o aninhamento de seletores no Sass é algo que não exige maiores explicações por ser bastante auto-explicativo. Veja um exemplo:

O .scss ...

#menu{
    ul{
        margin: 0px;
        padding: 0;
        li{
           list-style-type: none;
            a{
                text-decoration: none;
           }
        }
    }
}

… gera o.css:

#menu {
  background: #ddd; 
}
  #menu ul {
    margin: 0px;
    padding: 0;
  }
    #menu ul li {
      list-style-type: none; 
    }
      #menu ul li a {
        text-decoration: none;
      }

O problema do aninhamento é a sua facilidade. É tão fácil que se não tomarmos cuidado, podemos acabar com seletores do tipo:

main #mainContent #header #menu ul li a span.icon

Nós dois sabemos que seletores desse tipo são péssimos em termos de performance na renderização, os arquivos ficam mais pesados, ficam deselegantes e denigrem sua imagem como desenvolvedor. Nunca faça seletores desse tipo. (Para mim, isso é pior que usar o Dreamweaver ;)

Mas nós podemos usar o aninhamento para gerar o efeito hover em um link, juntamente com a referência ao seletor pai ‘&’. Veja:

o arquivo .scss ...

a{
    text-decoration: none;
    &:hover{
        text-decoration: underline;
    }
}

… gera o seguinte .css:


a{
     text-decoration: none;
}
a:hover{
     text-decoration: underline;
}

results matching ""

    No results matching ""