我有一个使用kendo-ui numericTextBox的表单
@Html.LabelFor(p => p.Cost)
@Html.TextBoxFor(p => p.Cost, new { @autocomplete = "off" })我绑定了它,然后,为了让它与jquery验证插件一起工作,我设置了以下设置:
$("#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包装器上)。
问题是,如果我再次按下submit按钮,(使用style="display: none;") kendo-ui元素就会消失。
我不知道是什么触发了这一切。我已经看到,如果将errorClass更改为input-validation-error以外的其他值,则kendo-ui小部件仍然可见。
这个问题只发生在kendo-ui控件上,而不是标准的html输入上。
我做错了什么吗?
发布于 2013-08-23 04:25:48
我敢打赌,数字文本框控件是双div包装的,就像datepicker控件一样。下面是我在validator配置中使用的highlight()和unhighlight()函数,用于确定要将error类应用于哪个元素:
...
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');
}
}发布于 2015-07-28 05:43:47
为了解决元素在第二次提交时消失的问题,我这样做了:
$("form").submit(function (event) {
$(".k-widget").removeClass("input-validation-error");
}https://stackoverflow.com/questions/16633498
复制相似问题