Mudei o gatilho de evento hide / show do Catalint com base na ideia de Glenns. Meu problema era que eu tenho um aplicativo modular. Eu mudo entre os módulos que mostram e ocultam divs pais. Então, quando oculto um módulo e mostro outro, com o método dele, tenho um atraso visível quando troco entre os módulos. Às vezes, só preciso iluminar esse evento e em algumas crianças especiais. Decidi notificar apenas os filhos com a classe "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;
}
});
Então, quando uma criança deseja ouvir o evento "show" ou "hide", tenho que adicionar a classe "displayObserver" e, quando ela não deseja continuar ouvindo, eu removo a classe
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);
},
Eu desejo ajuda