jquery - 重置验证并清除 Asp.Net MVC 自定义验证的验证消息

标签 jquery asp.net-mvc-3 unobtrusive-validation

我使用 MVC 3 和 jQuery 1.7.2,并且在客户端和服务器端实现了一些自定义验证,以验证某个文本区域在选中复选框时是否有文本。

我的客户端代码实现不显眼的验证如下所示:

 $.validator.addMethod("requiredif", function (value, element, params) {
    if (value) {
      var id = '#' + params["otherproperty"];
      var control = $(id);
      if (control.val() == '') {
        return false;
      }
    }

    return $.validator.methods.required.call(this, value, element, params);
});

$.validator.unobtrusive.adapters.add("requiredif", ["otherproperty"], function(options) {
   options.rules["requiredif"] = options.params;
   options.messages["requiredif"] = options.message;
});

我的问题是,即使我随后返回并取消选中该复选框(即不再需要文本),验证也会触发,验证消息仍保持不变并且验证不会被清除。

我已尝试以下方法来清除验证:

 $('#Dashboard').on('change', '#Damaged', null, function () {
   var validator = $('#Gridform').validate();
   validator.resetForm();
 });

但这没有任何区别。

我希望验证的工作方式与标准验证相同,即当我取消选中复选框或在文本区域中输入内容时,验证将被清除/重置。

最佳答案

尝试这个解决方案,它在我的项目中有效:

<button type="reset" onclick="$('.text-danger').hide();">Reset</ button>

<button type="submit" onclick="$('.text-danger').show();">Submit</button>

您也可以像在项目中一样更改选择器,在我的例子中,我将 (text-danger) 类添加到我的验证器中,如下所示:

@Html.ValidationMessageFor(model => model.fieldName, "", new { @class = "text-danger" })
<小时/>

此外,约翰·卡尔文纳 (John Culviner) 我发现了一个更好的解决方案,它运行得很好

1-包含jquery(页面结束)后编写此脚本:

<script>
    //clear validation on reset button clicked
    (function ($) { 
        //re-set all client validation given a jQuery selected form or child
        $.fn.resetValidation = function () {
            var $form = this.closest('form');

            //reset jQuery Validate's internals
            $form.validate().resetForm();

            //reset unobtrusive validation summary, if it exists
            $form.find("[data-valmsg-summary=true]")
                .removeClass("validation-summary-errors")
                .addClass("validation-summary-valid")
                .find("ul").empty();

            //reset unobtrusive field level, if it exists
            $form.find("[data-valmsg-replace]")
                .removeClass("field-validation-error")
                .addClass("field-validation-valid")
                .empty();

            return $form;
        };
    })(jQuery);
</script> 

2-添加点击事件调用Jquery函数

<button type="reset" onclick="$(this).resetValidation()" >Reset</button>

See here for article by John

关于jquery - 重置验证并清除 Asp.Net MVC 自定义验证的验证消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11687308/

相关文章:

jquery - 独立于库/框架的咆哮式通知?

jquery - 是否可以 "hack into"ASP.NET MVC 3 支持的非侵入式验证?

jQuery Validate Unobtrusive - Hook 到单个输入的错误事件

javascript - 如何在 jquery 中删除 slideUp

c# - 使用 Controller 返回的值填充图表

jquery - 模态响应高度

asp.net-mvc-3 - ASP.Net MVC 3 RadioButton 没有默认选择

c# - Ninject 3.0 不处理映射为 InRequestScope 的对象

entity-framework - 唯一字段 mvc 的客户端验证

asp.net-mvc-4 - ASP.NET MVC RemoteAttribute 验证不起作用 - 操作未执行