0

我是 PhoneGap 的新手,我正在使用数据库,并且可以使用以下代码正常工作

db = window.openDatabase("Sample", "1.0", "PhoneGap Demo", 200000);
    db.transaction(getDetails, transaction_error);

function transaction_error(tx, error) {
    $('#busy').hide();
    alert("Database Error: " + error);
}

function getUserDetails(tx) {
var sql = "select id, Name,  DisplayName from details where Name=Name";
    try {
        tx.executeSql(sql, [],getList_success);
    }
    catch(err)
    {
        alert(err);
    }
}

function getList_success(tx, results)
{
    var len = results.rows.length;
    for(var i=0; i <len; i++)
    {
        //Some code goes here
        }
    db = null;
}

现在我想使用这些函数getUserDetailsgetList_success通过传递参数,我尝试了下面的代码,它给出了错误

db = window.openDatabase("Sample", "1.0", "PhoneGap Demo", 200000);
    getUserDetails(db);


function getUserDetails(tx) {
var sql = "select id, Name,  DisplayName from details where Name=Name";
    try {
        tx.executeSql(sql, [],getList_success);
    }
    catch(err)
    {
        alert(err);
    }
}

错误TypeError:'undefined' is not a function在 catch 块中,任何人都可以帮助我解决这个问题吗?提前致谢

4

3 回答 3

1

executeSql 函数需要 4 个参数,试试这个:

function errorCallback(err){
//show error
}
...
tx.executeSql(sql, [],getList_success,errorCallback);
于 2013-04-09T06:32:56.683 回答
1

问题是您将回调函数移交给 db.transaction。如果你想向被调用者提供一些数据,你必须在调用者的上下文中使用闭包来提供这些数据。

var db = window.openDatabase("Sample", "1.0", "PhoneGap Demo", 200000);
var context = {val1: 'x', val2: 'y'};
db.transaction(function(tx){
        myfunction(tx,context);
    },
    tx_error,
    tx_success);

function myfunction(ty,context){
    tx.executeSql(query,[context.val1,context.val2],myf_success,myf_error);
}

请记住,这发生在一个新线程中!因此,如果您调用 db.transaction 请注意这同时发生在调用者身上。例如,如果您从 jQuery.ajax() 调用的成功回调内部调用 db.transaction(),则 ajax 线程将继续运行,并且可能在事务仍在进行时执行完整的回调。

于 2013-10-17T07:14:19.287 回答
-1

看看你的代码:

db.transaction(getDetails, transaction_error);

获取详细信息!

查看您声明的函数:

函数 getUserDetails(tx) {...}

函数 getList_success(tx, results) {....}

getDetails 不是 getUserDetails....

这就是您收到错误的原因。

于 2013-05-10T22:44:04.430 回答