jQuery Mobile"pagebeforechange"被调用两次

Jac*_*ack 6 jquery-mobile

我为"pagebeforechange"(非常类似于jQuery Mobile Documentation自己的代码)设置了以下监听器,并在主页上调用了http:// localhost /#product?id = 255979

//Bind Listener for Product Details
$(document).bind( "pagebeforechange", function( e, data ) {
    //Only Run If Site is Initialized
    if( ajaxSite.options.initialized ) {
        if ( typeof data.toPage === "string" ) {
            var u = $.mobile.path.parseUrl( data.toPage ),
                pl = /^#product/;

            if ( u.hash.search(pl) !== -1 ) {
                console.log("showProduct being called.");
                ajaxSite.showProduct( u, data.options );
                e.preventDefault();
            }
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

当我打开JavaScript控制台并单击链接时,我看到以下内容:

showProduct being called.
showProduct being called.
Run Code Online (Sandbox Code Playgroud)

我似乎无法找到任何关于为什么它会被调用两次的事情.我看到其他错误,其中vclicks由于边缘单击而被注册两次,但这没有任何意义,因为它依赖于实际的页面更改.

Phi*_*ord 6

因为您绑定到$(文档)并使用多页面布局

我认为jQM多次加载文档(只是一个预感)

切换到使用pageId代替,例如:

$(document).bind( "pagebeforechange", function( e, data ) { ...
Run Code Online (Sandbox Code Playgroud)

$('#pageId').bind( "pagebeforechange", function( e, data ) { ...
Run Code Online (Sandbox Code Playgroud)

  • 对我来说,使用v1.0插入pageId时不会触发事件...(另请参阅http://stackoverflow.com/questions/8793403/jquery-mobile-cant-bind-pagebeforechange-to-page-id ) (3认同)
  • @IanWarner你意识到这个例子是针对jQM 1.0的,从那以后发生了很多变化...... (2认同)