Ir para conteúdo
johnmfn

Alerta ao pressionar arroba

Recommended Posts

Pessoal, bom dia,

 

Tenho um sistema de login no site que é por CPF e analisando registros de logins inválidos é impressionante o que tem de gente que escreve o e-mail no campo CPF, mesmo a palavra CPF estando com letras garrafais, o cara tenta 10 vezes continuar fazendo login com e-mail e sai. Já pensei em restringir o input a numeros, mas acaba dando mais erros do que qualquer coisa, principalmente pelos autocompletar com mascaras, apesar de o PHP limpar pontos e traços

 

 

Enfim, estou colocando um alerta simples para caso o cara digita um "@" ele simplesmente dê um alert "nosso login é com CPF e não com e-mail".

 

É um código extremamente simples que não consigo fazer o if funcionar, alguém pode me apontar onde está o erro, eu já reli umas 50 vezes e não vejo nada de errado.

 

Na input pus:

<input onKeyPress="TeclaArroba()" name="login" id="login" type="text" value=''>

 

 

Nos script coloquei, ja testei 64, "64" e '64'

<script>
function TeclaArroba(){
if (event.keyCode == 64)) { 
    alert("Nosso login utiliza seu CPF, não seu e-mail.");
	}
}
</script>

 

Em teste já pus tambem abaixo e ele me dá uma alert de 64 quando digito "@", não sei porque o if não funciona.

<script>
function TeclaArroba(){
//if (event.keyCode == 64)) { 
    alert(event.keyCode);
}
//}
</script>

 

Agradeço

Compartilhar este post


Link para o post
Compartilhar em outros sites

Precisa ajustar dois pontos:

 

No HTML, é necessário informar que você passará o evento para a função...

 

<input onKeyPress="TeclaArroba(event)" />

No javascript, o mesmo deverá receber o evento para a devida tratativa.

 

function TeclaArroba(event) {
  if (event.keyCode === 64) { 
    alert(event.keyCode);
  }
}

Abraços!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Michael,

 

Muito obrigado pela orientação, funcionou perfeitamente para o que queria exceto em Android.....

 

Mas já pesquisei e é uma questão do KeyCode não funcionar nele, qualquer tecla retorna undefined, dei uma pesquisada sobre keycode, achei sobre o conhecido problema dele em Android e acabei resolvendo com uma pequena gambiarra de minha autoria. Segue o que fiz se alguem passar pelo mesmo problema, vários problemas de keycode no android podem ser resolvidos com o que fiz.

 

No Input tem que Usar Keyup

 

<input onKeyUp="TeclaArroba(event)" name="login" id="login" type="text" value=''>

A função gambiarrenta que funciona no Android ficou assim:

 

<script>
    function TeclaArroba(event) {
        var campo = document.getElementById('login');
        var conteudo = campo.value;
        var tamanho = conteudo.length;
        var tamanhoseg = tamanho -1;
        var ultima = conteudo.substring(tamanhoseg, tamanho);
        if (ultima === '@') {
            alert('Nosso sistema utiliza CPF e nao e-mail para login.');
        }                

    }
</script>

Pus um monte de variável que poderiam ser simplificadas, mas acho que elas tornam o script mais didático.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu não testei, mas tenta utilizar addEventListener ao invés de onKeyUp direto no elemento. Tem um exemplo bem aqui...

 

https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • 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>  
    • 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 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.