下面的函数总是返回‘插入序列:未定义’。我很难理解它为什么要这么做,如果我在console.log之前使用db.transaction,那么它会输出一个序列(只是一个数字)。为什么在db.transaction数据中突然没有定义?
var localSerials = [340, 234, 545, 239, 546];
function downloadUpdates(localSerials) {
console.log("Updating local database...");
$.getJSON("update.php", function(data) {
for (var i = 0; i < data.length; i++) {
if (localSerials.indexOf(data[i]) == -1) {
db.transaction(function (tx) {
tx.executeSql('INSERT INTO serials (serial) VALUES (' + data[i] + ')');
console.log("Inserted serial: " + data[i]);
});
}
}
});
}发布于 2013-10-11 03:29:43
异步事务位于for循环中,这会导致创建许多并行事务而不重用它们。将事务放到循环之外,并对所有请求重用事务。
var localSerials = [340, 234, 545, 239, 546];
function downloadUpdates(localSerials) {
console.log("Updating local database...");
$.getJSON("update.php", function(data) {
db.transaction(function (tx) {
for (var i = 0; i < data.length; i++) {
if (localSerials.indexOf(data[i]) == -1) {
tx.executeSql('INSERT INTO serials (serial) VALUES (' + data[i] + ')');
console.log("Inserted serial: " + data[i]);
});
}
}
});
}https://stackoverflow.com/questions/19302620
复制相似问题