jQuery中的2+(多个)电子邮件验证文本输入

时间:2013-07-29 15:25:30

标签: jquery validation email multiple-instances

我一直在研究这个问题几个小时,似乎无法使其发挥作用。 我在客户端部分需要多个电子邮件,位于相同的输入字段中。

现在我有(适用于一封电子邮件):

<script language="JavaScript">
$(document).ready(function(){
    $("form#editclient").validate({
            rules: {
            Contact: {
                required: true
            },
            Clientname: {
                required: true
            },
            ClientLogin: {
                required: true
            },
            ClientPassword: {
                required: true
            },
            email: {
                required: true,
                multiemail: true
            }
        },
        messages: {
            Contact: {
                required: "Please enter your Contact Nmae."
            },
            Clientname: {
                required: "Please enter your Client Name"
            },
            ClientLogin: {
                required: "Please enter a login."
            },
            ClientPassword: {
                required: "Please enter a password"
            },
            email: {
                required: "Please enter an Email Address",
                multiemail: "You must enter a valid email, or comma separate multiple"
            }
        }
});
});
</script>
    <input type="Text" id="email" name="Email" value="#Trim(Email)#" maxlength="60" class="inputText430 email required">

我发现这应该让多个验证器工作:

jQuery.validator.addMethod(
"multiemails",

function (value, element) {
    if (this.optional(element)) // return true on optional element
    return true;
    var email = value.split(/[;,]+/); // split element by , and ;
    valid = true;
    for (var i in email) {
        value = email[i];
        valid = valid && jQuery.validator.methods.email.call(this, $.trim(value), element);
    }
    return valid;
},

jQuery.validator.messages.multiemail);

但我无法让它正常工作。有人可以帮助我在一个文本字段中验证2个或更多电子邮件吗?

提前致谢。

(已编辑以在规则和消息中添加多重邮件) (用下面的解决方案编辑) 解

<form>
    <input id='emailTest' name='emailTest' />
    <input type='submit' />
</form>
    <script type="text/javascript">
    jQuery.validator.addMethod(
    "multiemail",
    function (value, element) {
        var email = value.split(/[;,]+/); // split element by , and ;
        valid = true;
        for (var i in email) {
            value = email[i];
            valid = valid && jQuery.validator.methods.email.call(this, $.trim(value), element);
        }
        return valid;
    },
    jQuery.validator.messages.multiemail
);

$("form").validate({
    debug: true,
    rules: {
            emailTest: {
                multiemail: true
            }
        },
    messages: {
            emailTest: {
                multiemail: "You must enter a valid email, or comma separate multiple"
            }
        },
    submitHandler: function(form) {
            return false;
        }
});

1 个答案:

答案 0 :(得分:12)

我认为代码中存在一些语义错误导致一些你不期待的事情发生。

我设法让你的自定义处理程序通过名称而不是按类型映射到字段来工作 - 我不确定覆盖在插件中是否有效。

rules: {
    emailTest: {
        multiemail: true
    }
}

同样在处理程序中,您有multiemails作为标识符,稍后将其称为multiemail,不确定其影响有多大。

以下是完整的工作示例:http://jsfiddle.net/jbergler/7jXn7/2/