Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Victor Oliveira Franco

Dúvida - Filtro de <div> com css e javascript

Recommended Posts

Pessoal, estou tentando ocultar alguns itens e exibir um botão de reset, com um comando do javascript, mas o filtro não está funcionando adequadamente. Alguém pode me ajudar?

 

O HTML

<!-- Seçoes / Botões -->
<div class="container">
  <div class="row">
    <div class="col-12"><p class="small text-right">Selecione um dos itens da lista</p></div>
    <div class="col-4 text-center" onClick="btn01()">
      <img src="http://epmeditora.com.br/newsite/assets/imagens/svg/health.svg" alt="mala, bag, bagagem, icone, icon" class="icone-site" width="100px">
      <h4 class="cor1">Educação Médica Continuada</h4>
    </div>

    <div class="col-4 text-center" onClick="btn02()">
      <img src="http://epmeditora.com.br/newsite/assets/imagens/svg/dos.svg" alt="mala, bag, bagagem, icone, icon" class="icone-site" width="100px">
      <h4 class="cor1">Projetos Médicos</h4>
    </div>

    <div class="col-4 text-center" onClick="btn03()">
      <img src="http://epmeditora.com.br/newsite/assets/imagens/svg/graphic.svg" alt="mala, bag, bagagem, icone, icon" class="icone-site" width="100px">
      <h4 class="cor1">Comercialização de Publicidade</h4>
    </div>
  </div>
  
  <!-- Separador -->
  <hr />
  
  <!-- Iténs do filtro -->
  <div class="container">
    <div class="row text-center">
    <div class="col-12"><p class="small text-right">Itens filtrados</p></div>
      <div class="col-12 col-sm-3 projeto-emc" id="projeto-emc">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/seminarios-em-ortopedia.jpg" class="figure-img img-fluid" alt="">
          <small>Projeto - Educação Médica Continuada</small>
      </div>
      <div class="col-12 col-sm-3 projeto-emc" id="projeto-emc">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/seminarios-em-ortopedia.jpg" class="figure-img img-fluid" alt="">
          <small>Projeto - Educação Médica Continuada</small>
      </div>
      <div class="col-12 col-sm-3 projeto-emc" id="projeto-emc">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/seminarios-em-ortopedia.jpg" class="figure-img img-fluid" alt="">
          <small>Projeto - Educação Médica Continuada</small>
      </div>

      <div class="col-12 col-sm-3 projeto-cp" id="projeto-cp">
        <div class="bg-secao boder-t-cor3">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/artigos-comentados.jpg" class="figure-img img-fluid" alt="">
          <small>Projetos Médicos</small>
        </div>
      </div>
      <div class="col-12 col-sm-3 projeto-cp" id="projeto-cp">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/artigos-comentados.jpg" class="figure-img img-fluid" alt="">
          <small>Projetos Médicos</small>
      </div>
      <div class="col-12 col-sm-3 projeto-cp" id="projeto-cp">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/artigos-comentados.jpg" class="figure-img img-fluid" alt="">
          <small>Projetos Médicos</small>
      </div>

      <div class="col-12 col-sm-3 projeto-pm" id="projeto-pm">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/50-faq.jpg" class="figure-img img-fluid" alt="">
          <small>Projeto - Comercialização de Publicidade</small>
      </div>
      <div class="col-12 col-sm-3 projeto-pm" id="projeto-pm">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/50-faq.jpg" class="figure-img img-fluid" alt="">
          <small>Projeto - Comercialização de Publicidade</small>
      </div>
      <div class="col-12 col-sm-3 projeto-pm" id="projeto-pm">
          <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/50-faq.jpg" class="figure-img img-fluid" alt="">
          <small>Projeto - Comercialização de Publicidade</small>
      </div>

      <div class="col-12 col-sm-3 reset" id="reset">
        <div class="bg-secao boder-t-cor2">
          BOTAO RESET
        </div>
      </div>
    </div>
  </div>

 

o CSS

.cor1{color:#3d92cd;}
#projeto-ems{display:block;}
#projeto-cp{display:block;}
#projeto-pm{display:block;}
#reset{display:none;}

 

o JAVASCRIPT

function btn01(){
    document.getElementById("projeto-emc").style.display="block";
    document.getElementById("pprojeto-cp").style.display="none";
    document.getElementById("projeto-pm").style.display="none";
    document.getElementById("reset").style.display="block";
}
function btn02(){
    document.getElementById("projeto-emc").style.display="none";
    document.getElementById("pprojeto-cp").style.display="block";
    document.getElementById("projeto-pm").style.display="none";
    document.getElementById("reset").style.display="block";
}
function btn03(){
    document.getElementById("projeto-emc").style.display="none";
    document.getElementById("pprojeto-cp").style.display="none";
    document.getElementById("projeto-pm").style.display="block";
    document.getElementById("reset").style.display="block";
}
function btn04(){
    document.getElementById("projeto-emc").style.display="none";
    document.getElementById("pprojeto-cp").style.display="none";
    document.getElementById("projeto-pm").style.display="none";
    document.getElementById("reset").style.display="block";
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá Victor, acompanhe as alterações que fiz no seu código:

 

<div class="container">
        <div class="row">
            <div class="col-12">
                <p class="small text-right">Selecione um dos itens da lista</p>
            </div>
            <div class="col-4 text-center" onClick="filter('projeto-emc')">
                <img src="http://epmeditora.com.br/newsite/assets/imagens/svg/health.svg" alt="mala, bag, bagagem, icone, icon" class="icone-site"
                    width="100px">
                <h4 class="cor1">Educação Médica Continuada</h4>
            </div>

            <div class="col-4 text-center" onClick="filter('projeto-cp')">
                <img src="http://epmeditora.com.br/newsite/assets/imagens/svg/dos.svg" alt="mala, bag, bagagem, icone, icon" class="icone-site"
                    width="100px">
                <h4 class="cor1">Projetos Médicos</h4>
            </div>

            <div class="col-4 text-center" onClick="filter('projeto-pm')">
                <img src="http://epmeditora.com.br/newsite/assets/imagens/svg/graphic.svg" alt="mala, bag, bagagem, icone, icon" class="icone-site"
                    width="100px">
                <h4 class="cor1">Comercialização de Publicidade</h4>
            </div>
        </div>

        <!-- Separador -->
        <hr />

        <!-- Iténs do filtro -->
        <div class="container">
            <div class="row text-center">
                <div class="col-12">
                    <p class="small text-right">Itens filtrados</p>
                </div>
                <div class="col-12 col-sm-3 item projeto-emc">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/seminarios-em-ortopedia.jpg" class="figure-img img-fluid" alt="">
                    <small>Projeto - Educação Médica Continuada</small>
                </div>
                <div class="col-12 col-sm-3 item projeto-emc">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/seminarios-em-ortopedia.jpg" class="figure-img img-fluid" alt="">
                    <small>Projeto - Educação Médica Continuada</small>
                </div>
                <div class="col-12 col-sm-3 item projeto-emc">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/seminarios-em-ortopedia.jpg" class="figure-img img-fluid" alt="">
                    <small>Projeto - Educação Médica Continuada</small>
                </div>

                <div class="col-12 col-sm-3 item projeto-cp">
                    <div class="bg-secao boder-t-cor3">
                        <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/artigos-comentados.jpg" class="figure-img img-fluid" alt="">
                        <small>Projetos Médicos</small>
                    </div>
                </div>
                <div class="col-12 col-sm-3 item projeto-cp">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/artigos-comentados.jpg" class="figure-img img-fluid" alt="">
                    <small>Projetos Médicos</small>
                </div>
                <div class="col-12 col-sm-3 item projeto-cp">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/artigos-comentados.jpg" class="figure-img img-fluid" alt="">
                    <small>Projetos Médicos</small>
                </div>

                <div class="col-12 col-sm-3 item projeto-pm">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/50-faq.jpg" class="figure-img img-fluid" alt="">
                    <small>Projeto - Comercialização de Publicidade</small>
                </div>
                <div class="col-12 col-sm-3 item projeto-pm">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/50-faq.jpg" class="figure-img img-fluid" alt="">
                    <small>Projeto - Comercialização de Publicidade</small>
                </div>
                <div class="col-12 col-sm-3 item projeto-pm">
                    <img src="http://epmeditora.com.br/newsite/assets/imagens/jpg/50-faq.jpg" class="figure-img img-fluid" alt="">
                    <small>Projeto - Comercialização de Publicidade</small>
                </div>

                <div class="col-12 col-sm-3 reset" id="reset">
                    <div class="bg-secao boder-t-cor2">
                        <button onclick="reset();">Botão de Reset</button>
                    </div>
                </div>
            </div>
        </div>
    </div>

Como você pode ter reparado, inseri a classe "item" em todos os elementos da filtragem, e os id's dos elementos agora estão como classes também, lembre-se, o ID cria uma identidade única para um elemento, e do ponto de vista de vista de semântica e acessibilidade só   pode ser atribuído a um único elemento por isso substituí por classes.

 

Já o javascript ficou da seguinte maneira:

function filter(el){
  var itens = document.getElementsByClassName('item');

  for(var i = 0; i < itens.length; i++){
    if(itens[i].classList.contains(el)){
      itens[i].style.display="block";
    }
    else{
      itens[i].style.display="none";
    }
  }
  document.getElementById("reset").style.display="block";
};

function reset(){
  var itens = document.getElementsByClassName('item');

  for(var i = 0; i < itens.length; i++){
    itens[i].style.display="block";
  }
  document.getElementById("reset").style.display="none";
};

Como você pode ver, criei uma função genérica chamada "filter" que recebe como parâmetro a classe dos elementos que você quer que apareçam após a filtragem, e criei uma outra função chamada "reset" que remove a filtragem e exibe novamente todos os itens.
Mas lembre-se, essa é apenas uma das várias maneiras de fazer, com tempo e estudo você vai ver que algumas libs e frameworks facilitam e muito a nossa vida na hora de fazer esse tipo de coisa.

 

Qualquer coisa estou a disposição para sanar dúvidas.  :)

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Pessoal, pergunta bem simples. Abaixo tenho o seguinte código:
       
      <script>
      function alerta()
      {
        if (window.confirm("Você realmente quer sair?")) {
          window.open("sair.html");
      }
      }
      </script>
       
      Funciona perfeitamente, só que está abrindo em outra janela e quero que abra na mesma janela.
       
      Alguém pode me ajudar?
    • Por Giovanird
      Olá a todos!
      Tenho uma pagina que possui uma DIV onde coloquei uma pagina PHP.
      Uso a função setInterval para atualizar a pagina inclusa dentro da DIV.
      O problema é que ao acessar o site , a DIV só me mostra a pagina inclusa somente quando completo o primeiro minuto.
      Preciso que a pagina inclusa já inicie carregada
       
      Meu código JavaScript e a DIV com a pagina PHP
       
      <script> function atualiza(){ var url = 'direita.php'; $.get(url, function(dataReturn) { $('#direita').html(dataReturn); }); } setInterval("atualiza()",60000); </script> <div> <span id="direita"></span> </div>  
    • Por Thiago Duarte
      Oi, gostaria de arrastar imagem e ao soltar formar bloco html, meu bloco de html ficaria com nome, content-1.html, content-2.html, etc
       
      Alguem pode me ajudar?
    • Por juliosonic
      Boa noite..
      Estou desenvolvendo um site de https://www.maithunatantra.com.br/ e estou com um duvida sobre o menu de navegação da versão mobile.
      O menu que tem o dropdown "Terapeutas" e "Terapias" quando clico em cima ele expande como deve ser, mas quando clico denovo para recolher os submenus
      nao acontece nada.. segue o trecho do codigo do menu..
      <div class="collapse navbar-collapse" id="navbarsExample09">             <ul class="navbar-nav ml-auto">               <li class="nav-item  active"><a class="nav-link" href="index.html">Home</a></li>               <li class="nav-item  active"><a class="nav-link" href="about-us.html">Quem Somos</a></li>               <li class="nav-item dropdown1">                     <a class="nav-link dropdown-toggle" data-toggle="dropdown1" href="#">Terapeutas</a>                     <ul class="dropdown-menu">                         <li><a class="dropdown-item" href="terapeuta-julio-cezar.html">Julio Cezar</a></li>                         <li><a class="dropdown-item" href="terapeuta-pamela-priscila.html">Pamela Priscila</a></li>                     </ul>                                    </li>               <li class="nav-item dropdown">                     <a class="nav-link dropdown-toggle" data-toggle="dropdown1" href="#">Terapias</a>                     <ul class="dropdown-menu" aria-labelledby="dropdown01">                         <li><a class="dropdown-item" href="o-que-e-reiki.html">O que é Reiki</a></li>                         <li><a class="dropdown-item" href="beneficios-reiki.html">Benefícios do Reiki</a></li>                         <li><a class="dropdown-item" href="principios-reiki.html">Princípios do Reiki</a></li>                         <li><a class="dropdown-item" href="animais-reiki.html">Reiki em Animais</a></li>                         <li><a class="dropdown-item" href="animais-reiki.html">Estudos Sobre Reiki</a></li>                         <li><a class="dropdown-item" href="terapia-massagem-tantrica.html">Terapia Tântrica</a></li>                     </ul>               </li>               <li class="nav-item  active"><a class="nav-link" href="blog.html">Blog</a></li>                <li class="nav-item"><a class="nav-link" href="contato.html">Contato</a></li>             </ul>         </div>  
      Massagem Tantrica em Curitiba
      Tantra Curitiba
      Massagem Tântrica
      Tantra
      Julio Darshan

      Obrigado
      Att
      Julio Cezar
       
       
       
    • Por belann
      Olá!
       
      Estou fazendo o upload de arquivos com fetch dessa forma
      fetch(url, {
              method: 'POST',
              headers: {'Content-Type': 'multipart/form-data',},
              body: formData 
          }).catch((error) => (console.log("Problemas com o Upload"), error));
       
      estou usando input type=file
      e criando uma const formData = new FormData(); 
      mas não faz e não dá nenhum erro.
      estou fazendo o upload com a url="http://localhost/dashboard/dados".
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.