事件不会发生

时间:2012-09-26 13:37:30

标签: javascript jquery html tiddlywiki

我有这些代码可能会破坏两个函数并为它们触发事件。然而,出于某种原因,事件似乎没有触发。他们按预期登录到控制台,但事件永远不会被触发。

//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();});

1 个答案:

答案 0 :(得分:3)

您需要指定bind到哪个元素,所以请尝试:

jQuery("#backstageArea").bind(...

而不是

jQuery.bind(...

(如果您使用的是jQuery 1.7+版本,您可能希望切换到.on() method - 为此目的具有相同的效果,但是建议的方法是从v1.7开始。 )