我有这些代码可能会破坏两个函数并为它们触发事件。然而,出于某种原因,事件似乎没有触发。他们按预期登录到控制台,但事件永远不会被触发。
//Show backstage event
(function( $, oldRem ){
backstage.show = function(){
console.log("yup, I'm the right one");
var resp = oldRem.apply( this, arguments );
$("#backstageArea").trigger("showBackstage");
return(resp);
};
})( jQuery, backstage.show );
//Hide backstage event
(function( $, oldRem ){
backstage.hide = function(){
console.log("And so am I.");
var resp = oldRem.apply( this, arguments );
if(anim && config.chkAnimate) {setTimeout( 'jQuery("#backstageArea").trigger("hideBackstage")', config.animDuration);}
else {$("#backstageArea").trigger("hideBackstage");}
return(resp);
};
})( jQuery, backstage.hide );
//Resize never logs its console message.
jQuery.bind("hideBackstage", function(){topbar.resize();});
jQuery.bind("showBackstage", function(){topbar.resize();});
答案 0 :(得分:3)
您需要指定bind
到哪个元素,所以请尝试:
jQuery("#backstageArea").bind(...
而不是
jQuery.bind(...
(如果您使用的是jQuery 1.7+版本,您可能希望切换到.on()
method - 为此目的具有相同的效果,但是建议的方法是从v1.7开始。 )