网站地图    收藏   

主页 > 前端 > javascript >

最全面的js验证电子邮箱的正则表达式

来源:自学PHP网    时间:2014-09-19 14:47 作者: 阅读:

[导读] 以前有写过很多邮箱正则表达式代码,下面我再来详细的介绍一个非常全面的电子邮箱验证程序,有需要的朋友可参考。...

先看如下一段代码:

 代码如下 复制代码
function isValidMail(sText){
var reMail = /^(?:w+.?)*w+@(?:w+.?)*w+$/;
return reMail.test(sText);
}

似乎这样验证像sofish@163.com这样的邮箱是没问题的。但,由于仔细看一下在AT(@)后面的非捕获性引用中,使用

的是*(出现任意次):

 代码如下 复制代码

var reMail = /^(?:w+.?)*w+@(?:w+.?)*w+$/;

那么,也包括出现0次,这样的话。像sofish@163com这样的邮箱也是通过验证的。 显然,"."是必须至少出现一次的

,因此,而"+"才表示至少出现一次。但这里,在AT后面,我们可以写像163.com.cn这样的结尾,但直接改成"+"的话

,这样163..com.cn也可以通过验证。下面是我的方法:

 代码如下 复制代码
function isValidMail(sText) {
var reMail = /^(?:w+.?)*w+@(?:w+.)+w+$/;
alert(reMail.test(sText))
}

规定"."号只出现一次。然后在非捕获引用后面,让其他至少显示1次,再以任意的字符结束。不过,这里的"w"是包

括下划线的,也就是说,像 sofish@163_.com_这样的邮件也是可能通过难的,显然,这是一个不合法的邮件,在AT后

面的"."号后前,是不可以出现下划线的,而后面,只能是英文字母的(至少目前我没有见过用后面是数字的域名)。并

且,这里应该注意到的是,"w"所代表的字符包括下划线,不用缩写是这样的

例1

 代码如下 复制代码

var _charset_email_extra = ".-_@";

function ValidateEMail(str) {
    var element2 = str.indexOf("@");
    if ((element2 > 0) && (str.substring(0, element2).indexOf("@") < 0) && (str.substring(element2 +

1).indexOf("@") < 0) && (str.substring(element2 + 1).indexOf(".") > 0) && (str.indexOf(".") > 0) &&

(str.lastIndexOf(".") < (str.length - 1))) {
        var i = IsDigiAlphExtra(str, _charset_email_extra);
        if (i >= 0) {
            return true;
        }
    } else {
        return true;
    }
    return false;
}
function IsDigiAlphExtra(str, charsetExtra) {
    for (var i = 0; i < str.length; i++) {
        var ch = str.charAt(i);
        if (!(((ch >= "A") && (ch <= "Z")) || ((ch >= "a") && (ch <= "z")) || ((ch >= "0") && (ch <=

"9")) || ((charsetExtra != null) && (charsetExtra.indexOf(ch) >= 0)))) {
            return i;
        }
    }
    return -1;
}

完整实例

 代码如下 复制代码


// 验证电子邮箱
// 注:不能给正则表达式加上“引号”
function checkEmail(obj) {
    var _email = $("#" + obj).val();
    //var emailRegExp = new RegExp(/^([a-zA-Z0-9]+[_|_|.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|_|.]?)*[a

-zA-Z0-9]+.[a-zA-Z]{2,3}$/);
    //var emailRegExp2 = new RegExp(/^w+((-w+)|(.w+))*@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+)*.[A-Za-

z0-9]+$/);
    //var emailRegExp3 = new RegExp(/^([a-zA-Z0-9]+[_|_|.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|_|.]?)*

[a-zA-Z0-9]+.(?:com|cn)$/);
 
    var reg1 = /^([a-zA-Z0-9]+[_|_|.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|_|.]?)*[a-zA-Z0-9]+.

(?:com|cn)$/;
    //var reg2 = /^([a-zA-Z0-9]+[_|_|.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|_|.]?)*[a-zA-Z0-9]+.[a-zA-

Z]{2,3}$/;
 
    if (!reg1.test(_email)) {
        alert(_email + "不是有效的email地址,请输入有效的E_mail!");
        $("#txtEmail").focus();
    }
    /*if (!reg2.test(_email)) {
        alert(_email + "不是有效的email地址,请输入有效的E_mail!");
        $("#txtEmail").focus();
    }
    if (!emailRegExp.test(_email)) {
        alert(_email + "不是有效的email地址,请输入有效的E_mail!");
        $("#txtEmail").focus();
    }
    if (!emailRegExp2.test(_email)) {
        alert(_email + "不是有效的email地址,请输入有效的E_mail!");
        $("#txtEmail").focus();
    }
    if (!emailRegExp3.test(_email)) {
        alert(_email + "不是有效的email地址,请输入有效的E_mail!");
        $("#txtEmail").focus();
    }
    if (_email.search(/^w+((-w+)|(.w+))*@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+)*.[A-Za-z0-9]+$/) == -1)

{
        alert(_email + "不是有效的email地址,请输入有效的E_mail!");
        $("#txtEmail").focus();
    }*/
}

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论