7

我有一个表格,它使用kendo-ui numericTextBox

@Html.LabelFor(p => p.Cost)
@Html.TextBoxFor(p => p.Cost, new { @autocomplete = "off" })

然后,我绑定它,使其与 jquery validate 插件一起使用,我设置了以下设置:

$("#Cost").kendoNumericTextBox({
    format: "c",
    min: 0,
    decimals: 2
});

$.validator.setDefaults({
    ignore: [],
    highlight: function (element, errorClass) {
        element = $(element);
        if (element.hasClass("k-input")) {
            element.closest(".k-widget").addClass(errorClass);

        } else {
            element.addClass(errorClass);
        }
    },
    unhighlight: function (element, errorClass) {
        element = $(element);
        if (element.hasClass("k-input")) {
            element.closest(".k-widget").removeClass(errorClass);
        } else {
            element.removeClass(errorClass);
        }
    }
});

当我尝试提交表单并且Cost输入无效时,它会正确添加errorClass(在.k-widget包装器上)。

问题是,如果我再次按下提交按钮,那么kendo-ui元素就会消失(带有style="display: none;")。

我不知道是什么触发了这个。我已经看到,如果我将 errorClass 更改为 以外的其他内容input-validation-error,则kendo-ui小部件仍然可见。

这个问题只发生在kendo-ui控件上,而不是标准的 html 输入。

我做错了什么?

4

2 回答 2

7

我打赌数字 texbox 控件是双 div 包装的,就像 datepicker 控件一样。以下是我在配置中用于确定将错误类应用于哪个元素的highlight()和函数:unhighlight()validator

...
highlight: function (element, errorClass, validClass) {
  var e = $(element),
      parent = _getParent(e);

    _addClass(e, parent);
  },
unhighlight: function (element, errorClass, validClass) {
  var e = $(element),
      parent = _getParent(e);

  _removeClass(e, parent);
}
...

function _getParent(element) {
  // a Kendo DatePicker is double-wrapped, so that requires us to return the parent of the parent
  return (element.parent().hasClass('k-picker-wrap')) ? element.parent().parent() : element.parent();
}

function _addClass (element, parent) {
  if (parent.hasClass('k-widget')) {
    parent.addClass('error');
  } else {
    element.addClass('error');
  }
}

function _removeClass(element, parent) {
  if (parent.hasClass('k-widget')) {
    parent.removeClass('error');
  } else {
    element.removeClass('error');
  }
}
于 2013-08-22T20:25:47.650 回答
3

为了解决元素在第二次提交时消失的问题,我这样做了:

$("form").submit(function (event) {
  $(".k-widget").removeClass("input-validation-error");
}
于 2015-07-27T21:43:46.583 回答