我正在使用WebSQL和IndexedDB开发一个Web应用程序。 IndexedDB在支持它的浏览器中运行良好,我的WebSQL实现在大多数浏览器中都有效,但是在Android上javascript执行似乎在db.transaction
内暂停。
这是我的代码。在"启动交易后,我没有收到控制台日志......" (似乎没有进一步的JS执行)。
window.store.getFile = function( filename, callback ) {
var db = window.store.websql.db;
console.log('Initiating transaction...');
db.transaction(function (tx) {
var filename2 = filename;
var query = 'SELECT * FROM file WHERE filename = "'+filename+'"';
console.log('Executing query:'+query);
tx.executeSql(query, [], function(t, r) {
if ( r.rows.length > 0 ) {
var len = r.rows.length, i;
for (i = 0; i < len; i++) {
var filename = r.rows.item(i).filename;
var data = r.rows.item(i).data;
if ( callback ) callback( true, filename2, data );
break; // Break here as only one result should be returned
}
} else {
if ( callback ) callback( false, filename2, null );
}
}, function(t, e) {
console.log(e);
if ( callback ) callback( false, filename2, null );
});
}, function(e) {
console.log('Database transaction error: '+e);
if ( callback ) callback( false, filename, null );
}, function() {
console.log('Transaction success');
});
console.log('Transaction initiated...');
};
(P.S。我也欢迎任何批评我的代码......)
答案 0 :(得分:3)
您正在追逐的错误可能是在db级别错误处理程序(在openDatabase中传递)中引发的。一些Android手机只是不接受null或未定义的错误处理程序症状是你所描述的。没有错误,没有成功......
另外:你的成功块应该在try / catch中,以防止该错误自动冒出来。
另外:请注意,成功处理程序的返回值(false / true)将确定抛出错误时发生的情况(回滚或只是没有回滚的错误)。