2021-06-15 16:21:20 +02:00
---
id: bad87fee1348bd8aedf06756
2021-06-27 23:51:13 +05:30
title: Sobrescrever estilos de classes por estilos de ID
2021-06-15 16:21:20 +02:00
challengeType: 0
videoUrl: 'https://scrimba.com/c/cRkpDhB'
forumTopicId: 18251
dashedName: override-class-declarations-by-styling-id-attributes
---
# --description--
2021-06-27 23:51:13 +05:30
No desafio anterior vimos que os navegadores leem o CSS de cima para baixo, seguindo a ordem de aparição das declarações de estilos. Isso significa que, em caso de conflito, o navegador utilizará a última declaração CSS escrita. No elemento `h1` , observe que se tivéssemos declarado a classe `blue-text` antes de classe `pink-text` , o h1 continuaria a aplicar os estilos baseado em quem foi declarado por último!
2021-06-15 16:21:20 +02:00
2021-06-27 23:51:13 +05:30
Mas isso não é tudo. Existem outras maneiras de sobrescrever o CSS. Você se lembra dos atributos de id?
2021-06-15 16:21:20 +02:00
2021-06-27 23:51:13 +05:30
Vamos sobrescrever as classes `pink-text` e `blue-text` dando ao elemento `h1` um id e então estilizar este id de forma a tornar o elemento `h1` laranja.
2021-06-15 16:21:20 +02:00
# --instructions--
2021-06-27 23:51:13 +05:30
Dê ao elemento `h1` o atributo `id` com o valor `orange-text` . Lembre-se de que é assim que se aplica um id:
2021-06-15 16:21:20 +02:00
```html
< h1 id = "orange-text" >
```
2021-06-27 23:51:13 +05:30
Não apague as classes `blue-text` e `pink-text` do elemento `h1` .
2021-06-15 16:21:20 +02:00
2021-06-27 23:51:13 +05:30
Crie uma declaração CSS para o id `orange-text` no elemento `style` . Um exemplo de como fazer isso:
2021-06-15 16:21:20 +02:00
```css
#brown-text {
color: brown;
}
```
2021-06-27 23:51:13 +05:30
**Observação:** não importa se você declara esse CSS acima ou abaixo da classe `pink-text` , já que o atributo `id` sempre terá prioridade.
2021-06-15 16:21:20 +02:00
# --hints--
2021-06-27 23:51:13 +05:30
O elemento `h1` deve ter a classe `pink-text` .
2021-06-15 16:21:20 +02:00
```js
assert($('h1').hasClass('pink-text'));
```
2021-06-27 23:51:13 +05:30
O elemento `h1` deve ter a classe `blue-text` .
2021-06-15 16:21:20 +02:00
```js
assert($('h1').hasClass('blue-text'));
```
2021-06-27 23:51:13 +05:30
O elemento `h1` deve ter o id `orange-text` .
2021-06-15 16:21:20 +02:00
```js
assert($('h1').attr('id') === 'orange-text');
```
2021-06-27 23:51:13 +05:30
Deve haver apenas 1 elemento `h1` .
2021-06-15 16:21:20 +02:00
```js
assert($('h1').length === 1);
```
2021-06-27 23:51:13 +05:30
O id `orange-text` deve ser referenciado no CSS.
2021-06-15 16:21:20 +02:00
```js
assert(code.match(/#orange -text\s*{/gi));
```
2021-06-27 23:51:13 +05:30
O `h1` não deve ter nenhum atributo `style` .
2021-06-15 16:21:20 +02:00
```js
assert(!code.match(/< h1. * style . * > /gi));
```
2021-06-27 23:51:13 +05:30
O elemento `h1` deve ser laranja.
2021-06-15 16:21:20 +02:00
```js
assert($('h1').css('color') === 'rgb(255, 165, 0)');
```
# --seed--
## --seed-contents--
```html
< style >
body {
background-color: black;
font-family: monospace;
color: green;
}
.pink-text {
color: pink;
}
.blue-text {
color: blue;
}
< / style >
< h1 class = "pink-text blue-text" > Hello World!< / h1 >
```
# --solutions--
```html
< style >
body {
background-color: black;
font-family: monospace;
color: green;
}
.pink-text {
color: pink;
}
.blue-text {
color: blue;
}
#orange -text {
color: orange;
}
< / style >
< h1 id = "orange-text" class = "pink-text blue-text" > Hello World!< / h1 >
```