10

我创建了自己的条件验证属性,通过继承RequiredAttribute和实现在客户端和服务器上验证我的 MVC 模型IClientValidatable。这个想法是,如果我的模型上的布尔属性为真,则需要另一个属性。在视图中,这表现为一个复选框,指示是否需要填写文本框。

除非用户执行以下操作,否则这非常有效:

  • 选中复选框(该字段现在是必需的)。
  • 提交表单(客户端验证运行,显示错误消息)。
  • 用户取消选中框(错误消息仍然存在,不再需要该字段)。

我想在选中或取消选中复选框时重新验证表单,或者甚至更好地重新验证该字段,以便不再显示错误消息。我尝试了调用 jQueryvalidate()方法的各种组合,但似乎没有什么能够重新运行验证。

我使用以下 javascript 来设置我的验证功能和相关的不显眼的适配器。

$.validator.addMethod(
    "requiredif",
    function(value, element, parameters) {
        var selector = "#" + parameters["dependentpropertyname"];
        var triggerValue = parameters["triggervalue"].toString().toLowerCase();
        var actualValue = $(selector).is(":checked").toString().toLowerCase();
        if (actualValue === triggerValue) return $.validator.methods.required.call(this, value, element, parameters);

        return true;
    });

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

谢谢!

4

2 回答 2

17

我有一个类似的问题,我想使用 jquery validate 和 jquery ui 重新验证 datepicker 字段。 这篇文章帮助我弄清楚了。

关键,只是为该选择器的有效方法添加一个回调。就像是:

$(".requiredif").change(function() {
  $(this).valid();
})
于 2012-10-11T19:39:03.600 回答
-5

您应该查看万无一失的验证。它可以完成您想要做的事情,而无需您自己动手。

于 2012-07-18T14:55:02.283 回答