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 Giovanird
      O script abaixo atualiza a página (centro.php) a cada um minuto e dentro desta página terei uma div que não poderá ser atualizada.
      Tentei colocar esta div como pagina com setInterval de 100 minutos porem ao dar o refresh no centro.php  tudo vai junto.  Será que isto é possivel?

      Desde já meu muito obrigado!
      <script> function atualiza(){ var url = 'centro.php'; $.get(url, function(dataReturn) { $('#centro').html(dataReturn); }); } setInterval("atualiza()",60000); </script>  

    • Por luiz monteiro
      Bom dia. Eu estou tentando encontrar uma maneira de evitar que após o usuário selecionar, se selecionar, uma imagem, essa seja substituída apenas por outra selecionada. Porém quando o usuário cancela a seleção, o input file remove o arquivo se já foi selecionado anteriormente.
      Essa é a estrutura que estou usando HTML
      form action="#" method="post" name="formulario" id="formulario" enctype="multipart/form-data"
      input type="file" name="file_name[]" br input type="file" name="file_name[]" br button enviar /button /form
      JS PURO
      Peguei esse script em um post aqui do stackoverflow e adaptei
      script type="text/javascript"
      let formulario = document.querySelector("#formulario"); formulario.addEventListener("change", (e)=>{ e.preventDefault(); var file = e.target.files[0]; if (e.target.files.length === 1 && e.target.files !== undefined && e.target.files !== null && file.type.match('image.*')) { console.log("if okay"); } else { //preciso entender o que devo fazer aqui para verificar se há arquivo no DOM desse target caso, o usuário cancele a seleção, para evitar que se há um arquivo no DOM esse permaneça. console.log(file); //CASO O USUÁRIO CANSELA A SELEÇÃO, RETORNA undefined } }); /script
      O if está correto, porém o que falta é o que fazer no else. Agradeço desde já.
    • Por ILR master
      Fala pessoal, tudo bem?
       
      Tô tentando fazer um pre-loading, mas não consigo de jeito algum.
      Quero mostrar uma animação enquanto a página é carregada e depois de caregada, esconder a animação e mostrar conteúdo.
       
      Aguém pode me ajudar?
       
      Segue código abaixo
       
       
      <!DOCTYPE html>
      <html lang="pt-br">
      <head>
          <meta charset="utf-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0" />  
          <title>PÁGINA LOAD</title>

      <style type="text/css">
      .loadclass {
          border: 2px solid #f3f3f3; /* Light grey */
          border-top: 4px solid #ffc401; /* Blue */
          border-radius: 50%;
          width: 50px;
          height: 50px;
          animation: spin 2s linear infinite;
      }
      @keyframes spin {
          0% { transform: rotate(0deg); }
          100% { transform: rotate(360deg); }
      }
      .conteudo {
          display:none;
      }
      </style>
      <script>
          function loading(){
              document.getElementsByClassName('loadclass')[0].style.display="none";
              document.getElementsByClassName('conteudo').style.display="block";
          }
      </script>
      </head>
      <body onLoad="loading()">
      <div class="loadclass"></div>
      <div class="conteudo">SEU CONTEUDO AQUI DENTRO!!!</div>
      </body>
      </html>
    • 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>  
×

Informação importante

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