在jQuery中覆盖显示函数使PrimeFaces咆哮保持可见



我需要覆盖特定元素的显示函数。到目前为止,这工作正常。但是有一个邪恶的副作用:我的咆哮元素在显示后仍然可见。控制台中没有日志错误,其他内容工作正常。它也不会卡在任何地方。它只是在显示后再也不会隐藏。

这是我的jQuery函数:

jQuery(function($) {
            jQuery.fn.oldshow = jQuery.fn.show;
            jQuery.fn.show = function() {
                //Use old function
                return jQuery(this).oldshow();
            };
        });

这里是咆哮元素:

  <p:growl id="growl" showDetail="true" />

如果没有 jQuery 函数,它会按预期工作并再次隐藏。

得到一些提示或解决方案会很棒。

我已经尝试将其替换为:

jQuery(function($) {
            var oldshow = $.fn.show;
            $.fn.show = function(args) {
                var t = $(this);
                return oldshow.apply(t, arguments);
            };
        });

没有区别

覆盖 primefaces 函数而不是 jquery 函数

PrimeFaces.widget.Growl.prototype.show = (function() {
 var oldFunction = PrimeFaces.widget.Growl.prototype.show;
 return function() {
    //some logic
    //use old function
    return oldFunction.apply(this, arguments);
 };
})();

最新更新