0

如果验证器找到“@”符号,如何创建检查电子邮件是否有效的方法?(输入文本仅为姓名或电子邮件地址)。

4

2 回答 2

3
function checkMail(email){
    var filter  = /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
    if (filter.test(email)) {
        return true;
    }
    return false;
}

checkMail('me@domain.com'); // return true or false if invalid.

如果写入了有效域,这将另外检查电子邮件地址。

me@something --> 无效
的@something.com --> 无效的
me@.com --> 无效
的 me@something.com --> 有效

正则表达式库 -->

如果您想使用 jQuery 验证引擎验证邮件地址,只需添加:

data-validation-engine="validate[required,custom[email]]"

到输入字段。


从表单验证引擎 1.6.4开始,可以添加自己的验证功能:http ://www.position-absolute.com/news/form-validation-engine-1-6-4/

您可以用这个替换示例中的代码,然后它应该可以工作:

<input value="" data-validation-engine="validate[required,funcCall[nameOrMail]]" class="text-input nameOrMail" type="text" name="req" id="req" />

JS(给你的<head>):

jQuery(document).ready(function(){
    jQuery("#formID").validationEngine({
        "nameOrMail": {
            "nname":"nameOrMail"
        }
    });
});

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

function nameOrMail(){
    if($(".nameOrMail").val().indexOf('@') >= 0){
        if(!checkMail($(".nameOrMail").val())) {
            return "Please enter a valid mail address or name!";
        }
    } else {
        if($(".nameOrMail").val() === '') {
            return "Please enter a valid mail address or name!";
        }
    }
}

现场演示:http: //jsfiddle.net/4dUyX/

于 2012-06-05T10:23:07.647 回答
0

使用拆分功能,那么您将不需要正则表达式

<script>
function check(email){
    if (email.split("@").length>0) {
        return true;
    }
   else return false;
}

check('jfvh@yahoo.com'); </script>
于 2012-06-05T10:26:31.590 回答