3
respostas

[Sugestão] Resolução com data-Attribute

No desafio, está descrito para criarmos 2 botões, então fiz desse jeito. Segue o código:

html:

<body>

  <button id="botao">Mostrar Cores</button>

  <button class="close">Esconder Cores</button>

  <ul class="lista" data-lista>
    <li cor="laranja" tipo="tinta-exterior" class="item">Tinta laranja</li>
    <li cor="vermelho" tipo="tinta-interior" class="item">Tinta vermelha</li>
    <li cor="branco" tipo="tinta-interior" class="item">Tinta branca</li>
    <li cor="amarelo" tipo="tinta-exterior" class="item">Tinta amarela</li>
    <li cor="rosa" tipo="tinta-exterior" class="item">Tinta rosa</li>
    <li cor="preto" tipo="tinta-exterior" class="item">Tinta preta</li>
  </ul>

  <a href="https://alura.com.br/" target="_blank"><img src="https://www.alura.com.br/assets/img/home/alura-logo.svg" alt="" class="alura-logo"></a>

  <script src="./main.js"></script>
</body>

Javascript:

const botao = document.querySelector("#botao");
const cores = document.querySelector('[data-lista]');
const botaoClose = document.querySelector('.close');

botao.addEventListener('click', () => {
  cores.setAttribute('data-lista', 'mostrar')
})

botaoClose.addEventListener('click', () => {
  cores.setAttribute('data-lista', 'esconder')
})

E se precisar, tá aqui o CSS:

* {
  margin: 0;
  padding: 0;
}

body {
  font-family: "Roboto Mono", monospace;
  min-height: 400px;
  min-width: 450px;
  background-size: 80vh;
  color: rgb(0, 0, 0);
  background-image: url("https://www.uniabeu.edu.br/wp-content/uploads/2020/03/fundo-lilas.png");
  background-size: cover;
  background-repeat: no-repeat;
  height: 100vh;
  font-size: 24px;
  font-weight: bold;
  display: flex;
  align-items: center;
  flex-direction: column;
}

button {
  font-size: 24px;
  font-family: "Futura Lt BT", sans-serif;
  background-color: black;
  background-repeat: no-repeat;
  cursor: pointer;
  overflow: hidden;
  outline: none;
  padding: 8px 20px 8px 20px;
  color: white;
  box-shadow: 0px 0px 5px gray;
  border-radius: 5px 5px 0 0;
  border: none;
  transition: 500ms;
  opacity: 0.8;
  margin: 30px 0;
}

button:hover {
  color: white;
  background-color: gray;
}

button:active {
  color: black;
  background-color: white;
}

.lista {
  display: none;
  padding: 20px;
  list-style-type: none;
  border: 4mm ridge rgba(234, 122, 11, 0.992);
}

.alura-logo {
  width: 150px;
  position: absolute;
  top: 2%;
  right: 2%;
}

[cor="laranja"] {
  color: orange;
}

[cor="vermelho"] {
  color: red;
}

[cor="branco"] {
  color: white;
}

[cor="amarelo"] {
  color: yellow;
}

[cor="rosa"] {
  color: pink;
}

[cor="preto"] {
  color: black;
}

[data-lista="mostrar"] {
  display: block; 
} 
[data-lista="esconder"] { 
  display: none; 
}

3 respostas

Olá Rafael, tudo bem?

Achei bem legal a solução que você implementou utilizando o atributo data. Muito obrigada por compartilhar com a gente o seu resultado, e parabéns por praticar com o desafio proposto no curso.

Um abraço e bons estudos.

sua resolução me esclareceu bastante, obrigada, rafael!

Solução muito boa. Só uma duvida. Quando vc coloca cores.setAttribute('data-lista', 'esconder') vc adiciona o atributo display: none. Esse atributodo é sobre carregado sempre que adiciona um novo comando ou ele vai adicionando atributos no elemento e esse elemento vai ficando sobrecarregado com o tempo?