PhoneGap / JQuery Mobile dbShell问题

时间:2011-11-11 02:05:59

标签: jquery-mobile cordova

每次用户更改phonegap应用中的页面时,我都会尝试进行查询。我是Phonegap / JQuery Mobile的新手,但不了解发生了什么。

当我点击一个按钮时,pagebeforechange将被调用两次。

第一次它正常工作。下一次调用时,它不会运行dbshel​​l.transaction,也不会显示错误。因此,如果我首先单击概述页面,它会起作用,但另一页则不起作用。如果我先单击其他页面,则概述页面不起作用。在这两种情况下,重新访问同一页面都不会重新执行查询。

这里发生了什么?我调用dbshel​​l的方式一定是不正确的吗?

//Listen for any attempts to call changePage().
$(document).bind( "pagebeforechange", function( e, data ) {
    alert("pagebeforechange");
    // We only want to handle changePage() calls where the caller is
    // asking us to load a page by URL.
    if ( typeof data.toPage === "string" ) {
        // We are being asked to load a page by URL, but we only
        // want to handle URLs that request the data for a specific
        // category.
        var u = $.mobile.path.parseUrl( data.toPage ),
            reOverviewPage = /^#overviewPage/,
            reViewByType = /^#viewByType/,
            pageUrl=data.toPage;
        var params = parseParams(pageUrl.substr(pageUrl.lastIndexOf("?") + 1));
        if ( u.hash.search(reOverviewPage) !== -1 ) {
            alert("overview");
            dbShell.transaction(function(tx) {
                alert("doing query");
                 tx.executeSql("select _id, description from area where _id=?",[params['id']],renderOverview,dbErrorHandler);
            },dbErrorHandler);              
        } else if (u.hash.search(reViewByType) !== -1 ) {

            alert("viewByType");
            dbShell.transaction(function(tx) {
                try 
                {
                    alert("!");
                    tx.executeSql("select trip.* from trip, trip_type, trip_type_lookup where trip_type.trip_id = trip._id and trip_type_lookup._id = trip_type.trip_type_lookup_id and lower(trip_type_lookup.type_name) = ?",[params['type']],dbErrorHandler, renderViewByType);
                } 
                catch(e) 
                {
                    alert(e.message);
                }

            },dbErrorHandler);
        }
    }
});

0 个答案:

没有答案