Cambié el desencadenador de evento de ocultar / mostrar de Catalint basado en la idea de Glenns. Mi problema fue que tengo una aplicación modular. Cambio entre módulos que muestran y ocultan padres divs. Luego, cuando oculto un módulo y muestro otro, con su método tengo un retraso visible cuando cambio entre módulos. Solo necesito a veces iluminar este evento, y en algunos niños especiales. Así que decidí notificar solo a los niños con la clase "displayObserver"
$.each(["show", "hide", "toggleClass", "addClass", "removeClass"], function () {
var _oldFn = $.fn[this];
$.fn[this] = function () {
var hidden = this.find(".displayObserver:hidden").add(this.filter(":hidden"));
var visible = this.find(".displayObserver:visible").add(this.filter(":visible"));
var result = _oldFn.apply(this, arguments);
hidden.filter(":visible").each(function () {
$(this).triggerHandler("show");
});
visible.filter(":hidden").each(function () {
$(this).triggerHandler("hide");
});
return result;
}
});
Luego, cuando un niño quiere escuchar el evento "show" u "hide", debo agregarle la clase "displayObserver", y cuando no quiere continuar escuchándolo, lo elimino de la clase
bindDisplayEvent: function () {
$("#child1").addClass("displayObserver");
$("#child1").off("show", this.onParentShow);
$("#child1").on("show", this.onParentShow);
},
bindDisplayEvent: function () {
$("#child1").removeClass("displayObserver");
$("#child1").off("show", this.onParentShow);
},
Deseo ayuda