Validação do e-mail com o jQuery

Sou novo no jQuery e queria saber como usá-lo para validar endereços de E-mail.

Author: Robert Koritnik, 2010-03-24

30 answers

Pode usar o javascript normal para isso:

function isEmail(email) {
  var regex = /^([a-zA-Z0-9_.+-])+\@(([a-zA-Z0-9-])+\.)+([a-zA-Z0-9]{2,4})+$/;
  return regex.test(email);
}
 623
Author: Fabian, 2015-10-16 14:52:13

Função JQuery para validar o e-mail

Eu realmente não gosto de usar plugins, especialmente quando meu formulário só tem um campo que precisa ser validado. Uso Esta função e chamo-a sempre que preciso de validar um campo de formulário de E-mail.

 function validateEmail($email) {
  var emailReg = /^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/;
  return emailReg.test( $email );
}

E agora usar este

if( !validateEmail(emailaddress)) { /* do stuff here */ }
Saúde!
 149
Author: Manish Shrivastava, 2015-03-02 16:34:45

Eu usaria o 'plugin' de validação do jQuery por algumas razões.

Validaste, está bem? e agora? Você precisa exibir o erro, lidar apagando-o quando é válido, mostrando quantos erros totais talvez? Há muitas coisas que ele pode lidar para você, sem necessidade de reinventar a roda.

Além disso, outro grande benefício é que ele está hospedado em um CDN, a versão atual no momento desta resposta pode ser encontrada aqui: http://www.asp.net/ajaxLibrary/CDNjQueryValidate16.ashx isto significa tempos de carga mais rápidos para o cliente.

 39
Author: Nick Craver, 2010-03-24 12:36:19

Veja http:/ /bassistance.de/jquery-plugins/jquery-plugin-validation/. é um bom 'plugin' de jQuery, que permite criar um sistema de validação 'powerfull' para os formulários. Existem algumas amostras úteis aqui. Então, a validação do campo de E-mail no formulário irá parecer assim:

$("#myform").validate({
  rules: {
    field: {
      required: true,
      email: true
    }
  }
});

Ver documentação do método de E-mail para mais detalhes e amostras.

 29
Author: Andrew Bashtannik, 2016-11-22 12:13:26

<!-- Dont forget to include the jQuery library here -->
<script type="text/javascript" src="jquery-1.3.2.min.js"></script>
<script type="text/javascript">

$(document).ready(function() {

    $("#validate").keyup(function(){

        var email = $("#validate").val();

        if(email != 0)
        {
            if(isValidEmailAddress(email))
            {
                $("#validEmail").css({
                    "background-image": "url('validYes.png')"
                });
            } else {
                $("#validEmail").css({
                    "background-image": "url('validNo.png')"
                });
            }
        } else {
            $("#validEmail").css({
                "background-image": "none"
            });         
        }

    });

});

function isValidEmailAddress(emailAddress) {
    var pattern = new RegExp(/^(("[\w-\s]+")|([\w-]+(?:\.[\w-]+)*)|("[\w-\s]+")([\w-]+(?:\.[\w-]+)*))(@((?:[\w-]+\.)*\w[\w-]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][0-9]\.|1[0-9]{2}\.|[0-9]{1,2}\.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\.){2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\]?$)/i);
    return pattern.test(emailAddress);
}

</script>

<style>
    #validEmail
    {
        margin-top: 4px;
        margin-left: 9px;
        position: absolute;
        width: 16px;
        height: 16px;
    }

    .text
    {
        font-family: Arial, Tahoma, Helvetica;
    }
</style>

    <title>Live Email Validation with jQuery Demo</title>
</head>
<body>
    <div class="text"><h1>Reynoldsftw.com - Live Email Validation</h1><h2>Type in an email address in the box below:</h2></div>
    <div><input type="text" id="validate" width="30"><span id="validEmail"></span></div>
    <div class="text"><P>More script and css style

: www.htmldrive.net


Source:htmldrive.com

 14
Author: SwatiKothari, 2013-09-03 18:56:08
Eu recomendaria Verimail.js , Ele também tem um plugin JQuery . Porquê? O Verimail suporta o seguinte:
  • validação da sintaxe (de acordo com a RFC 822)
  • validação IANA TLD
  • sugestão ortográfica para os TLDs e domínios de E-mail mais comuns
  • negar domínios temporários da conta de E-mail como: mailinator.com
Para além da validação, Verimail.o js também lhe dá sugestões. Então, se você digitar um e-mail com o TLD ou domínio errado que é muito semelhante a um domínio de E-mail comum (hotmail.com, gmail.com, etc), Ele pode detectar isso e sugerir uma correção.

Exemplos:

E assim por diante..

Para usá-lo com jQuery, basta incluir verimail.Forum.js na tua local e executar a função abaixo:

$("input#email-address").verimail({
    messageElement: "p#status-message"
});

O elemento mensagem é um elemento no qual uma mensagem será mostrada. Isto pode ser tudo, desde "seu email é inválido" até", você quis dizer ...?".

Se tiver um formulário e quiser restringi-lo para que não possa ser enviado a menos que o e-mail seja válido, então poderá verificar o estado usando a função getVerimailStatus como mostrado abaixo:

if($("input#email-address").getVerimailStatus() < 0){
    // Invalid
}else{
    // Valid
}

Esta função devolve um código de estado inteiro de acordo com o objecto Comfirm.AlphaMail.Muito mal.Status. Mas a regra geral é que quaisquer códigos abaixo de 0 são códigos que indicam erros.

 13
Author: Robin Orheden, 2012-10-06 13:09:01
<script type="text/javascript">
    $(document).ready(function() {
      $('.form_error').hide();
      $('#submit').click(function(){
           var name = $('#name').val();
           var email = $('#email').val();
           var phone = $('#phone').val();
           var message = $('#message').val();
           if(name== ''){
              $('#name').next().show();
              return false;
            }
            if(email== ''){
               $('#email').next().show();
               return false;
            }
            if(IsEmail(email)==false){
                $('#invalid_email').show();
                return false;
            }

            if(phone== ''){
                $('#phone').next().show();
                return false;
            }
            if(message== ''){
                $('#message').next().show();
                return false;
            }
            //ajax call php page
            $.post("send.php", $("#contactform").serialize(),  function(response) {
            $('#contactform').fadeOut('slow',function(){
                $('#success').html(response);
                $('#success').fadeIn('slow');
               });
             });
             return false;
          });
      });
      function IsEmail(email) {
        var regex = /^([a-zA-Z0-9_\.\-\+])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
        if(!regex.test(email)) {
           return false;
        }else{
           return true;
        }
      }
  </script>

<form action="" method="post" id="contactform">
                            <table class="contact-table">
                              <tr>
                                <td><label for="name">Name :</label></td>
                                <td class="name"> <input name="name" id="name" type="text" placeholder="Please enter your name" class="contact-input"><span class="form_error">Please enter your name</span></td>
                              </tr>
                              <tr>
                                <td><label for="email">Email :</label></td>
                                <td class="email"><input name="email" id="email" type="text" placeholder="Please enter your email" class="contact-input"><span class="form_error">Please enter your email</span>
                                  <span class="form_error" id="invalid_email">This email is not valid</span></td>
                              </tr>
                              <tr>
                                <td><label for="phone">Phone :</label></td>
                                <td class="phone"><input name="phone" id="phone" type="text" placeholder="Please enter your phone" class="contact-input"><span class="form_error">Please enter your phone</span></td>
                              </tr>
                              <tr>
                                <td><label for="message">Message :</label></td>
                                <td class="message"><textarea name="message" id="message" class="contact-input"></textarea><span class="form_error">Please enter your message</span></td>
                              </tr>
                              <tr>
                                <td></td>
                                <td>
                                  <input type="submit" class="contactform-buttons" id="submit"value="Send" />
                                  <input type="reset" class="contactform-buttons" id="" value="Clear" />
                                </td>
                              </tr>
                            </table>
     </form>
     <div id="success" style="color:red;"></div>
 13
Author: user1993920, 2013-01-31 01:35:50

function isValidEmailAddress(emailAddress) {
    var pattern = /^([a-z\d!#$%&'*+\-\/=?^_`{|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+(\.[a-z\d!#$%&'*+\-\/=?^_`{|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+)*|"((([ \t]*\r\n)?[ \t]+)?([\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|\\[\x01-\x09\x0b\x0c\x0d-\x7f\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))*(([ \t]*\r\n)?[ \t]+)?")@(([a-z\d\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|[a-z\d\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF][a-z\d\-._~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]*[a-z\d\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])\.)+([a-z\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|[a-z\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF][a-z\d\-._~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]*[a-z\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])\.?$/i;
    return pattern.test(emailAddress);
};
if( !isValidEmailAddress( emailaddress ) ) { /* do stuff here (email is invalid) */ }
Esta resposta foi fornecida pelo utilizador Luca Filosofi nesta resposta.
 13
Author: Amila kumara, 2017-05-23 11:55:10

Isto realiza uma validação mais completa, por exemplo, verifica-se com pontos sucessivos no nome do utilizador, tais como: [email protected]

function isValidEmail(email)
{
    return /^[a-z0-9]+([-._][a-z0-9]+)*@([a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,4}$/.test(email)
        && /^(?=.{1,64}@.{4,64}$)(?=.{6,100}$).*/.test(email);
}

Ver validar o endereço de E-mail usando uma expressão regular em JavaScript.

 8
Author: Geek, 2013-10-14 11:22:34

Uma solução muito simples é usar a validação html5:

<form>
  <input type="email" required pattern="[^@]+@[^@]+\.[a-zA-Z]{2,6}">

  <input type="submit">
</form>

Http://jsfiddle.net/du676/56/

 8
Author: iamse7en, 2017-09-18 05:57:21

Se você tem um formulário básico, basta fazer o tipo de entrada de E-mail: <input type="email" required>

Isto vai funcionar para navegadores que usam atributos HTML5 e então você nem sequer precisa de JS. Basta usar a validação de E-mail mesmo com alguns dos scripts acima não vai fazer muito desde:

[email protected] [email protected] [email protected]

Etc... Todos validarão como e-mails" reais". Por isso, seria melhor garantir que o utilizador tem de introduzir o seu endereço de E-mail duas vezes para se certificar de que coloca o o mesmo. Mas para garantir que o endereço de E-mail é real seria muito difícil, mas muito interessante para ver se havia uma maneira. Mas se você está apenas se certificando de que é um e-mail, fique com a entrada HTML5.

EXEMPLO DE VIOLINO

Isto funciona no FireFox e no cromado. Pode não funcionar no Internet Explorer... Mas o internet explorer não presta. Então, há isso...
 7
Author: isaac weathers, 2014-03-04 04:09:45
function isValidEmail(emailText) {
    var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);
    return pattern.test(emailText);
};

Usar Assim:

if( !isValidEmail(myEmail) ) { /* do things if myEmail is valid. */ }
 6
Author: JayKandari, 2013-11-07 08:09:17
function validateEmail(emailaddress){  
   var emailReg = /^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/;  
   if(!emailReg.test(emailaddress)) {  
        alert("Please enter valid email id");
   }       
}
 5
Author: JAB, 2011-11-04 06:01:36
<script type = "text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
<script type = "text/javascript">
    function ValidateEmail(email) {
        var expr = /^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$/;
        return expr.test(email);
    };
    $("#btnValidate").live("click", function () {
        if (!ValidateEmail($("#txtEmail").val())) {
            alert("Invalid email address.");
        }
        else {
            alert("Valid email address.");
        }
    });
</script>
<input type = "text" id = "txtEmail" />
<input type = "button" id = "btnValidate" value = "Validate" />
 4
Author: Pritam, 2014-12-02 04:51:16
Aterrei aqui.....acabou aqui.: https://html.spec.whatwg.org/multipage/forms.html#valid-e-mail-address

...que contém a seguinte expressão regular:

/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/

...que eu encontrei graças a uma nota no plugin de validação jQuery readme: https://github.com/jzaefferer/jquery-validation/blob/master/README.md#reporting-an-issue

Então, a versão actualizada de @Fabian's resposta seria:

function IsEmail(email) {
  var regex = /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;
  return regex.test(email);
}
Espero que isso ajude.
 4
Author: timborden, 2017-05-23 12:10:42

Utilize este

if ($this.hasClass('tb-email')) {
    var email = $this.val();
    var txt = /^([a-zA-Z0-9_\.\-\+])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
    if (!txt.test(email)) {
        e.preventDefault();
        $this.addClass('error');
    } else {
        $this.removeClass('error');
    }
}
 3
Author: Ankit Agrawal, 2014-03-11 15:15:18

Para aqueles que querem usar uma solução melhor que possa ser mantida do que fósforos disruptivos com um RegEx de um ano-luz, escrevi algumas linhas de código. Aqueles que querem salvar bytes, sigam a variante RegEx:)

Isto restringe:

  • no @ in string
  • nenhum ponto no texto
  • mais de 2 Pontos após @
  • caracteres inválidos no nome de utilizador (antes de@)
  • mais de 2 @ no texto
  • caracteres inválidos no domínio
  • más notas em subdomain
  • caracteres inválidos no TLD
  • endereços TLD
De qualquer forma, ainda é possível vazar, por isso, certifique-se de combinar isto com uma validação do lado do servidor + verificação do link de E-mail.

Aqui está o JSFiddle

 //validate email

var emailInput = $("#email").val(),
    emailParts = emailInput.split('@'),
    text = 'Enter a valid e-mail address!';

//at least one @, catches error
if (emailParts[1] == null || emailParts[1] == "" || emailParts[1] == undefined) { 

    yourErrorFunc(text);

} else {

    //split domain, subdomain and tld if existent
    var emailDomainParts = emailParts[1].split('.');

    //at least one . (dot), catches error
    if (emailDomainParts[1] == null || emailDomainParts[1] == "" || emailDomainParts[1] == undefined) { 

        yourErrorFunc(text); 

     } else {

        //more than 2 . (dots) in emailParts[1]
        if (!emailDomainParts[3] == null || !emailDomainParts[3] == "" || !emailDomainParts[3] == undefined) { 

            yourErrorFunc(text); 

        } else {

            //email user
            if (/[^a-z0-9!#$%&'*+-/=?^_`{|}~]/i.test(emailParts[0])) {

               yourErrorFunc(text);

            } else {

                //double @
                if (!emailParts[2] == null || !emailParts[2] == "" || !emailParts[2] == undefined) { 

                        yourErrorFunc(text); 

                } else {

                     //domain
                     if (/[^a-z0-9-]/i.test(emailDomainParts[0])) {

                         yourErrorFunc(text); 

                     } else {

                         //check for subdomain
                         if (emailDomainParts[2] == null || emailDomainParts[2] == "" || emailDomainParts[2] == undefined) { 

                             //TLD
                             if (/[^a-z]/i.test(emailDomainParts[1])) {

                                 yourErrorFunc(text);

                              } else {

                                 yourPassedFunc(); 

                              }

                        } else {

                             //subdomain
                             if (/[^a-z0-9-]/i.test(emailDomainParts[1])) {

                                 yourErrorFunc(text); 

                             } else {

                                  //TLD
                                  if (/[^a-z]/i.test(emailDomainParts[2])) {

                                      yourErrorFunc(text); 

                                  } else {

                                      yourPassedFunc();
}}}}}}}}}
 3
Author: SEsterbauer, 2016-03-18 13:12:13
checkRegexp( email, /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i, "eg. [email protected]" );

Refernce: JQUERY UI WEBSITE

 2
Author: danielad, 2013-06-20 14:52:59

Devias ver isto: jquery.validar.JS,adiciona-o ao teu projecto

Usando-o assim:

<input id='email' name='email' class='required email'/>
 2
Author: Chuanshi Liu, 2015-03-24 01:39:08

Outra opção simples e completa:

<input type="text" id="Email"/>
<div id="ClasSpan"></div>   
<input id="ValidMail" type="submit"  value="Valid"/>  


function IsEmail(email) {
    var regex = /^([a-zA-Z0-9_.+-])+\@(([a-zA-Z0-9-])+\.)+([a-zA-Z0-9]{2,4})+$/;
    return regex.test(email);
}

$("#ValidMail").click(function () {
    $('span', '#ClasSpan').empty().remove();
    if (IsEmail($("#Email").val())) {
        //aqui mi sentencia        
    }
    else {
        $('#ClasSpan').append('<span>Please enter a valid email</span>');
        $('#Email').keypress(function () {
            $('span', '#itemspan').empty().remove();
        });
    }
});
 2
Author: jorcado, 2015-09-30 07:15:21

Validação de E-mail Javascript no MVC / ASP.NET

O problema com que me deparei ao usar a resposta de Fabian, é implementá-la numa visão MVC por causa do símbolo Razor. Você tem que incluir um símbolo @ adicional para escapar dele, assim: @@ Para evitar Razor no MVC.
function isEmail(email) {
  var regex = /^([a-zA-Z0-9_.+-])+\@@(([a-zA-Z0-9-])+\.)+([a-zA-Z0-9]{2,4})+$/;
  return regex.test(email);
}
Não o vi noutra página, por isso achei que podia ser útil.

Editar

Aqui está um link da Microsoft descrevendo o seu uso.
I apenas testei o código acima e obtive o seguinte js:

function validateEmail(email) {
  var regex = /^([a-zA-Z0-9_.+-])+\@(([a-zA-Z0-9-])+\.)+([a-zA-Z0-9]{2,4})+$/; 
  return regex.test(email);
}
Que está a fazer exactamente o que é suposto fazer.
 2
Author: Trevor Nestman, 2018-08-08 21:22:10
if($("input#email-address").getVerimailStatus() < 0) { 

(incorrect code)

}

if($("input#email-address").getVerimailStatus() == 'error') { 

(right code)

}
 1
Author: Lorenzo, 2013-03-19 22:10:23

O erro está no 'Plugin' de validação do Jquery, só valida com @ para alterar este

Muda o código para este

email: function( value, element ) {
    // From http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#e-mail-state-%28type=email%29
    // Retrieved 2014-01-14
    // If you have a problem with this implementation, report a bug against the above spec
    // Or use custom methods to implement your own email validation
    return this.optional( element ) || /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/.test( value );
}
 1
Author: user4974898, 2015-06-04 18:17:54
Um simplificado que acabei de fazer, faz o que preciso. Limitei-o a apenas alfanumérico, período, sublinhado e @.
<input onKeyUp="testEmailChars(this);"><span id="a"></span>
function testEmailChars(el){
    var email = $(el).val();
    if ( /^[[email protected]]+$/.test(email)==true ){
        $("#a").html("valid");
    } else {
        $("#a").html("not valid");
    }
}

Feito com a ajuda de outros

 1
Author: nathan, 2015-07-19 18:48:48

Esta expressão regular evita nomes de domínio duplicados como [email protected], permitirá apenas domínio duas vezes como [email protected]. It also does not allow statring from number like [email protected]

 regexp: /^([a-zA-Z])+([a-zA-Z0-9_.+-])+\@(([a-zA-Z])+\.+?(com|co|in|org|net|edu|info|gov|vekomy))\.?(com|co|in|org|net|edu|info|gov)?$/, 
Tudo De Bom !!!!!
 1
Author: Brijeshkumar, 2015-11-03 08:53:31

Valide o e-mail ao escrever, com o tratamento do Estado do botão.

$("#email").on("input", function(){
    var email = $("#email").val();
    var filter = /^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$/;
    if (!filter.test(email)) {
      $(".invalid-email:empty").append("Invalid Email Address");
      $("#submit").attr("disabled", true);
    } else {
      $("#submit").attr("disabled", false);
      $(".invalid-email").empty();
    }
  });
 1
Author: Radovan Skendzic, 2016-08-04 07:25:44

Você pode usar a validação do jQuery e, numa única linha HTML, poderá validar o e-mail e a mensagem de validação do E-mail: type="email" required data-msg-email="Enter a valid email account!"

Você pode usar o parâmetrodata-msg-email para colocar uma mensagem personalizada ou não colocar este parâmetro e a mensagem por omissão será apresentada: "indique por favor um endereço de E-mail válido."

Exemplo Completo:

<form class="cmxform" id="commentForm" method="get" action="">
  <fieldset>
    <p>
      <label for="cemail">E-Mail (required)</label>
      <input id="cemail" type="email" name="email" required data-msg-email="Enter a valid email account!">
    </p>
    <p>
      <input class="submit" type="submit" value="Submit">
    </p>
  </fieldset>
</form>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.validate.js"></script>
<script>
$("#commentForm").validate();
</script>
 1
Author: gras, 2017-11-14 15:07:30

Pode criar a sua própria função

function emailValidate(email){
    var check = "" + email;
    if((check.search('@')>=0)&&(check.search(/\./)>=0))
        if(check.search('@')<check.split('@')[1].search(/\./)+check.search('@')) return true;
        else return false;
    else return false;
}

alert(emailValidate('[email protected]'));
 1
Author: Wahid Masud, 2018-03-16 14:25:22
Como mencionado acima, este é suficientemente bom para mim.
var regex = /^([a-zA-Z0-9_.+-])+\@(([a-zA-Z0-9-])+\.)+([a-zA-Z0-9]{2,4})+$/;

Mas se não quiser que o fim do domínio (. com,. nu,. Net etc) contenha números (que é a minha escolha pré-definida), a versão editada será :

var regex = /^([a-zA-Z0-9_.+-])+\@(([a-zA-Z0-9-])+\.)+([a-zA-Z]{2,4})+$/;
 0
Author: anoraq, 2014-09-05 07:25:55

Utilizar jquery.validar.js , Tem Microsoft ajax CDN.

$('#form').validate({
    rules:{
        "name":{
            required:true,
            maxlength:40
        },

        "email":{
            required:true,
            email:true, //for validate email
            maxlength:100
        },

        "message":{
            required:true
        }
    }
});
 0
Author: NaveenDA, 2016-08-04 06:17:49