1

我正在构建一个 phonegap 应用程序。我正在使用 web sql,在数据检索之前一切正常。

function getItemGroups(){

    var items_groups = new Array();
    var db = window.openDatabase("merbokDB", "1.0", "MerbokDB", 5232394);

    db.transaction(
        function(tx){
            tx.executeSql('SELECT * FROM item_groups',[],
                function(tx,result){
                    if(result.rows.length > 0){

                        var len = result.rows.length;

                        for (var i=0; i<len; i++){

                            items_groups.push(result.rows.item(i).item_group);

                        }
                        console.log(items_groups.join());

                    }
                }
                ,errorCB);
        },
        errorCB);

    return items_groups;
}
var myproducts = getItemGroups();

我的问题是当我运行代码时“myproducts”变量是空白的。但我可以看到

console.log(items_groups.join());

以下行在控制台中打印值。我回来的方式有错吗?

4

1 回答 1

3

我不是 100% 熟悉您正在使用的框架,但一个很好的猜测是传递到链中每个步骤的函数用于异步回调。因此,不能保证它们会在运行的语句之前运行。所以本质上发生的是这条线:

return items_groups;

在执行任何这些内部函数之前执行。所以它只是返回它的初始值,它是一个空数组。

片刻之后(甚至可能是几毫秒之后),内部函数被执行并看到控制台日志输出。

当使用这样的异步功能时,您不能依赖按顺序执行的代码行序列。而不是“在下一行”执行你的逻辑,你必须在某种回调函数中执行它。在这种情况下,检索数据后的最终回调似乎是这样的:

function(tx,result){
    if(result.rows.length > 0){

        var len = result.rows.length;

        for (var i=0; i<len; i++){

            items_groups.push(result.rows.item(i).item_group);

        }
        console.log(items_groups.join());

    }
}

无论您要对myproducts变量做什么,都需要在该函数中启动。

于 2013-06-25T16:25:02.407 回答