Update ValidationSummary list on control blurs?
A ValidationSummary mostrará una lista de errores en la devolución de datos. A medida que se arregla cada campo, se activa su validador y cualquier texto de validación desaparecerá. Quiero actualizar automáticamente ValidationSummary también.
Lo siguiente funciona bien:
<asp:TextBox ID="ForenameTextBox" onblur="ValidationSummaryOnSubmit()" runat="server" />
pero esto no es ideal, ya que significa cambiar y mantener esto en todos los campos. ValidationSummaryOnSubmit
es una función de Microsoft.) Así que intenté hacerlo dinámicamente:
addEvent(window, "load", UpdateValidationSummary);
function addEvent(obj, evType, fn) {
if (obj.addEventListener) {
obj.addEventListener(evType, fn, true);
} else {
if (obj.attachEvent) {
var r = obj.attachEvent("on" + evType, fn);
return r;
}
}
}
function removeEvent(obj, evType, fn) {
if (obj.removeEventListener) {
obj.removeEventListener(evType, fn, true);
return true;
} else if (obj.detachEvent) {
var r = obj.detachEvent("on" + evType, fn);
return r;
}
}
function UpdateValidationSummary() {
if (typeof (Page_Validators) == "undefined") {
return;
}
var i, val, ctrl;
for (i = 0; i < Page_Validators.length; i++) {
val = Page_Validators[i];
if (val.controltovalidate != null && val.controltovalidate != "") {
ctrl = document.getElementById(val.controltovalidate);
if (ctrl != null && typeof (ValidationSummaryOnSubmit) == "function") {
//add call to ValidationSummary on blur
addEvent(ctrl, "blur", ValidationSummaryOnSubmit);
}
}
}
}
in embargo, esto no funciona: todo ValidationSummary desaparece cuando se corrige un campo y parece que se llama dos veces a la función ValidationSummaryOnSubmit. Si uso una tarea simple en lugar de laaddEvent
a función @ funciona, pero quiero atender los campos que ya pueden tener algo en elonBlur
evento.
ásicamente creo que solo necesito agregar una llamada a laValidationSummaryOnSubmit
función a la "lista" deonBlur
manejadores para cada control. ¿Por qué el código anterior no parece hacer esto?