2
respostas

[Projeto] Minha versão da solução

Edit: Caramba! agora que vi a Opinião do Instrutor, abriu ainda mais minha mente! Vou refazer manipulando data-attributes no css!

Olá! Tentei fazer de uma maneira que fazia mais sentido pra mim e aproveitei pra usar um pouco do que tenho aprendido por fora tbm.

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title>Manipulando o DOM - Aula 3</title>
  <link rel="stylesheet" href="./style.css">
</head>
<body>

  <button>Aluratintas em estoque:</button>
  <button data-botao="">Exibir Lista</button>


  <ul class="lista lista-oculta">
    <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>
</html>
* {
    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 {
    padding: 20px;
    list-style-type: none;
    border: 4mm ridge rgba(234, 122, 11, 0.992);
    clip-path: circle(100%);
    transition: 1s;
  }

  .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;
  }

  .lista-oculta{
    clip-path: circle(0);
    transition: 1s;

  }
const botao = document.querySelector('[data-botao]');
const lista = document.querySelector('.lista');
let listaEstaOculta = true;

botao.addEventListener('click', () => {
    if(listaEstaOculta === true){
        listaEstaOculta = false;
        botao.textContent = 'Ocultar Lista';
        lista.classList.remove('lista-oculta');
    }else{
        listaEstaOculta = true;
        botao.textContent = 'Exibir Lista';
        lista.classList.add('lista-oculta');
    }

})
2 respostas

Versão Atualizada

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title>Manipulando o DOM - Aula 3</title>
  <link rel="stylesheet" href="./style.css">
</head>
<body>

  <button>Aluratintas em estoque:</button>
  <button data-botao="">Exibir Lista</button>


  <ul class="lista" data-lista="esconder">
    <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>
</html>
* {
    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 {
    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='esconder']{
    clip-path: circle(0);
    transition: 1s;

  }

  [data-lista='mostrar']{
    clip-path: circle(100%);
    transition: 1s;
  }
const botao = document.querySelector('[data-botao]');
const lista = document.querySelector('.lista');

botao.addEventListener('click', () => {
    if(lista.dataset.lista == 'esconder'){
        lista.setAttribute('data-lista', 'mostrar');
    }else{
        lista.setAttribute('data-lista', 'esconder');
    }
})

Oi Alexander, tudo bem?

Fico feliz em ver que você está aplicando seus conhecimentos em JavaScript e CSS para criar soluções que fazem sentido para você. É muito importante experimentar e testar diferentes abordagens para encontrar a que melhor se adapta às suas necessidades.

Sobre o seu código, percebi que você está manipulando a classe "lista-oculta" para exibir ou ocultar a lista de tintas. Essa é uma ótima forma de manipular o DOM com JavaScript. Além disso, você está usando data-attributes no CSS para definir a cor das tintas. Isso é uma boa prática que ajuda a manter o código organizado e semântico.

Um abraço e bons estudos.