0

我有一些可以正常工作的 HTML 5 验证,但我现在需要向它添加一些自定义验证以检查 2 个输入元素是否具有相同的值。但到目前为止,它只是被忽略了。这是我的代码,对无效的更改进行了注释:

<script type="text/javascript">
    $(document).ready(function () {

        //set up buttons
        $(function () {
            $("input:submit").button();
        });
    });
</script>    

<!--IE doesn't support setCustomValidity--> 
<![if !IE]>
<script type="text/javascript">
    //http://www.whatwg.org/specs/web-apps/current-work/multipage/association-of-controls-and-forms.html#the-constraint-validation-api
    $(document).ready(function () {

        //set up buttons
        $(function () {
            $("input:submit").button();
        });

        //added to compare Name and Email Address
        var name = $("#Name").val();
        var emailAddress = $("#EmailAddress").val();

        if ((name == emailAddress) && (name != "")) {
            $("#Name").setCustomValidity("Name must not be equal to Email Address");
            return false;
        }

        var elementsInput = document.getElementsByTagName("input");
        var elementsTextArea = document.getElementsByTagName("textarea");

        for (var i = 0; i < elementsInput.length; i++) {

            elementsInput[i].oninvalid = function (e) {
                e.target.setCustomValidity("");
                if (!e.target.validity.valid) {

                    switch (e.target.name) {

                        case "Name":
                            e.target.setCustomValidity("@Html.Raw(Resources.Validation.FullNameRequired)");
                            break;

                        case "EmailAddress":
                            //e.preventDefault();

                            //later you decide you want to submit
                            //$(this).unbind('submit').submit();

                            if (e.target.validity.valueMissing) {
                                e.target.setCustomValidity("@Html.Raw(Resources.Validation.EmailAddressRequired)");
                            }
                            else if (e.target.validity.patternMismatch) {
                                e.target.setCustomValidity("@Html.Raw(Resources.Validation.EmailAddressInvalid)");
                            }
                            break;

                        case "PhoneNumber":
                            //e.preventDefault();
                            if (e.target.validity.valueMissing) {
                                e.target.setCustomValidity("@Html.Raw(Resources.Validation.PhoneNumberRequired)");
                            }
                            else if (e.target.validity.patternMismatch) {
                                e.target.setCustomValidity("@Html.Raw(Resources.Validation.PhoneNumberInvalid)");
                            }
                            break;
                        }
                    }
            };
                elementsInput[i].oninput = function (e) {
                    e.target.setCustomValidity("");
                };
            }

        for (var j = 0; j < elementsTextArea.length; j++) {
            elementsTextArea[j].oninvalid = function (e) {
                e.target.setCustomValidity("");
                if (!e.target.validity.valid) {
                    switch (e.target.name) {
                        case "Details":
                            e.target.setCustomValidity("@Html.Raw(Resources.Validation.DetailsRequired)");
                            break;
                    }
                }
            };
            elementsTextArea[j].oninput = function (e) {
                e.target.setCustomValidity("");
            };
        }
    });

</script>
<![endif]>
4

0 回答 0