freeCodeCamp/curriculum/challenges/portuguese/01-responsive-web-design/basic-css/override-all-other-styles-b...

2.7 KiB

id title challengeType videoUrl forumTopicId dashedName
bad87fee1348bd9aedf07756 Sobrescrever todos os outros estilos usando a palavra important 0 https://scrimba.com/c/cm24rcp 18249 override-all-other-styles-by-using-important

--description--

Uhuu! Acabamos de provar que os estilos inline sobrescrevem todas as declarações CSS feitas no elemento style.

Mas veja bem. Existe mais uma forma de sobrescrever o CSS que declaramos anteriormente. Este é o método mais poderoso de todos. Mas antes de continuarmos, vamos falar sobre o motivo de você querer substituir o CSS.

Em muitas situações, você usará bibliotecas CSS. E elas podem, acidentalmente, substituir o CSS. Portanto, quando você precisar ter certeza absoluta de que um elemento deve possuir um CSS específico, poderá usar !important.

Vamos voltar à nossa classe pink-text. Lembre-se de que a classe pink-text foi sobrescrita por declarações de classe posteriores, declarações de id e estilos inline.

--instructions--

Vamos adicionar a palavra-chave !important à declaração de estilo do elemento h1 para ter 100% de certeza de que ele terá a cor de texto rosa.

Um exemplo de como fazer isso:

color: red !important;

--hints--

O elemento h1 deve ter a classe pink-text.

assert($('h1').hasClass('pink-text'));

O elemento h1 deve ter a classe blue-text.

assert($('h1').hasClass('blue-text'));

O elemento h1 deve ter o atributo id de valor orange-text.

assert($('h1').attr('id') === 'orange-text');

O elemento h1 deve ter o estilo inline color: white.

assert(code.match(/<h1.*style/gi) && code.match(/<h1.*style.*color\s*?:/gi));

A classe pink-text deve ter a palavra-chave !important para sobrescrever todas as outras declarações.

assert(
  code.match(/\.pink-text\s*?\{[\s\S]*?color:.*pink.*!important\s*;?[^\.]*\}/g)
);

O elemento h1 deve ser rosa.

assert($('h1').css('color') === 'rgb(255, 192, 203)');

--seed--

--seed-contents--

<style>
  body {
    background-color: black;
    font-family: monospace;
    color: green;
  }
  #orange-text {
    color: orange;
  }
  .pink-text {
    color: pink;
  }
  .blue-text {
    color: blue;
  }
</style>
<h1 id="orange-text" class="pink-text blue-text" style="color: white">Hello World!</h1>

--solutions--

<style>
  body {
    background-color: black;
    font-family: monospace;
    color: green;
  }
  #orange-text {
    color: orange;
  }
  .pink-text {
    color: pink !important;
  }
  .blue-text {
    color: blue;
  }
</style>
<h1 id="orange-text" class="pink-text blue-text" style="color: white">Hello World!</h1>