Email validation is easy to get wrong. I would therefore recommend that you use Verimail.js.
Why?
- Syntax validation (according to RFC 822).
- IANA TLD validation
- Spelling suggestion for the most common TLDs and email domains
- Deny temporary email account domains such as mailinator.com
- jQuery plugin support
Another great thing with Verimail.js is that it has spelling suggestion for the most common email domains and registered TLDs. This can lower your bounce rate drastically for users that misspell common domain names such as gmail.com, hotmail.com, aol.com, aso..
Example:
- test@gnail.com -> Did you mean test@gmail.com?
- test@hottmail.con -> Did you mean test@hotmail.com?
How to use it?
The easiest way is to download and include verimail.jquery.js on your page.
After that, hookup Verimail by running the following function on the input-box that needs the validation:
$("input#email-address").verimail({
messageElement: "p#status-message"
});
The message element is an optional element that displays a message such as "Invalid email.." or "Did you mean test@gmail.com?". If you have a form and only want to proceed if the email is verified, you can use the function getVerimailStatus as shown below:
if($("input#email-address").getVerimailStatus() < 0){
// Invalid email
}else{
// Valid email
}
The getVerimailStatus-function returns an integer code according to the object Comfirm.AlphaMail.Verimail.Status. As shown above, if the status is a negative integer value, then the validation should be treated as a failure. But if the value is greater or equal to 0, then the validation should be treated as a success.