微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript-使用WebSQL进行回调(Phonegap)

我正在使用Phonegap& Sencha Touch.我有带Sencha界面的viewport.js文件和具有所有数据库和请求功能的databaseFunctions.js.

我想在viewport.js中调用此行:

if(launchRequest('SELECT * from items',nombreItems)) alert('there are items');

这是简化的功能:

function launchRequest(requete,callback){
    var db = openDatabase('database', '1.0', 'database', 2 * 1024 * 1024);

    db.transaction(function (tx) {

        tx.executeSql(requete,[],
        function (tx, results) {        
            return callback(results.rows.length);
        });

    });
}
function nombreItems(num) {return num;}

我不知道如何获取函数的返回值.通常,我在函数的末尾有一个返回值(在标准SQL中),但是在这里,结果将传输到另一个函数.

解决方法:

这段代码将满足您的要求,因为WebSQL接口是异步的,您不能“返回”值.

launchRequest('SELECT * from items',nombreItems);

function launchRequest(requete,callback){
    var db = openDatabase('database', '1.0', 'database', 2 * 1024 * 1024);

    db.transaction(function (tx) {

        tx.executeSql(requete,[],
        function (tx, results) {        
            callback(results.rows.length);
        });

    });
}
function nombreItems(num) {
    if(num){
        alert('there are items');
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐