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>