2011-11-19 148 views
7

通常簡單的電子郵件的驗證是:的Javascript多個電子郵件正則表達式驗證

/^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/ 

這將驗證像[email protected]

但如何驗證,如果郵件是多個電子郵件?

entry 1: [email protected], [email protected], [email protected] 
entry 2: [email protected] , [email protected] , [email protected] 
entry 3: [email protected], [email protected] , [email protected] 
entry 4: [email protected] 

此電子郵件是用戶可能輸入的條目。另外預計他們有時會收到2或3或4或更多的電子郵件。

感謝您的答案。

回答

11

分割上一個逗號的電子郵件和驗證項

var x = getEmails(); 
var emails = x.split(","); 
emails.forEach(function (email) { 
    validate(email.trim()); 
}); 

凡getEmails()獲取網頁的電子郵件,並驗證運行你對電子郵件的正則表達式

1

你應該能夠分裂通過逗號輸入,然後針對正則表達式測試各個電子郵件子條目。

var valid = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/; 
var entries = entry.split(","); 

if(valid.test(entries[0]))... //or however your testing against the regex 

您可能還想在測試任何剝離的電子郵件子字符串之前修剪任何空格。

0

嘗試此jQuery驗證:

jQuery.validator.addMethod("multiemail", function (value, element) { 
    if (this.optional(element)) { 
     return true; 
    } 
    var emails = value.split(','), 
     valid = true; 
    for (var i = 0, limit = emails.length; i < limit; i++) { 
     value = emails[i]; 
     valid = valid && jQuery.validator.methods.email.call(this, value, element); 
    } 
    return valid; 
}, "Invalid email format: please use a comma to separate multiple email addresses."); 
4

試試這個

function validateEmails(string) { 
     var regex = /^([\w-\.][email protected]([\w-]+\.)+[\w-]{2,4})?$/; 
     var result = string.replace(/\s/g, "").split(/,|;/);   
     for(var i = 0;i < result.length;i++) { 
      if(!regex.test(result[i])) { 
       return false; 
      } 
     }  
     return true; 
    } 

接受逗號和分號作爲分隔

0

function validateEmail(emailAddress) { 
 
    var emailPattern = /^(([^<>()[\]\\.,;:\[email protected]\"]+(\.[^<>()[\]\\.,;:\[email protected]\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; 
 
    return emailPattern.test(emailAddress); 
 
} 
 

 
function validate() { 
 
    $("#result").text(""); 
 
    var email = $("#emailAddress").val(); 
 
    if (validateEmail(email)) { 
 
    $("#result").text(email + " validation successful"); 
 
    $("#result").css("color", "white"); 
 
    } else { 
 
    $("#result").text(email + " validation failed"); 
 
    $("#result").css("color", "red"); 
 
    } 
 
    return false; 
 
} 
 

 
$("form").bind("submit", validate);
.divSection{ 
 
    text-align: center; padding: 8%; 
 
    } 
 
.pSection{ 
 
    border: none; color: white; padding: 10px 100px; text-align: center; text-decoration: none; display: inline-block; font-size: 24px; margin: 3% 0%; border-radius: 6px; -webkit-transition-duration: 0.4s; transition-duration: 0.4s; font-family: Roboto-Regular,Helvetica,Arial,sans-serif; background-color: #4184f3; margin: auto;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 

 
<div class="divSection"> 
 
<form action="dashboard/user/profile" method="POST"> 
 
    <input id="emailAddress" placeholder="Enter Email" value="[email protected]"> 
 
    <input type='submit' value="check"> 
 
</form> 
 
    </div> 
 

 
<div class="divSection" > 
 
<p class="pSection" id='result'></p> 
 
</div>

這是JavaScript代碼來檢查,如果郵件中包含一個以上的@字符

var count=0; 
email = "[email protected]@gmail.com"; 
alert(email); 
for(i =0; i<email.length;i++){ 
if(email.charAt(i) == "@"){ 
count++; 
}} 
if(count>1){ 
    alert("not ok") 
} else { 
    alert("ok") 
} 

另一種方法是通過使用電子郵件的標準模式

var pattern= /^(([^<>()\[\]\\.,;:\[email protected]"]+(\.[^<>()\[\]\\.,;:\[email protected]"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; 
re.test(email); 
相關問題