Javascript 变量在web sql事务中不再可访问?

Javascript 变量在web sql事务中不再可访问?,javascript,sql,web-sql,Javascript,Sql,Web Sql,下面的函数总是返回“插入的序列:未定义”。我很难理解它为什么要这样做,如果在db.transaction之前我console.log,它就会输出一个序列号(只是一个数字)。为什么db.transaction数据[i]内部突然没有定义 var localSerials = [340, 234, 545, 239, 546]; function downloadUpdates(localSerials) { console.log("Updating local database.

下面的函数总是返回“插入的序列:未定义”。我很难理解它为什么要这样做,如果在db.transaction之前我
console.log
,它就会输出一个序列号(只是一个数字)。为什么db.transaction数据[i]内部突然没有定义

  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]);
          });
        }
      }
    });
  }
var localSerials=[3402345456];
函数下载更新(localSerials){
log(“更新本地数据库…”);
$.getJSON(“update.php”,函数(数据){
对于(变量i=0;i
异步事务位于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]);
        });
      }
    }
  });
}
var localSerials=[3402345456];
函数下载更新(localSerials){
log(“更新本地数据库…”);
$.getJSON(“update.php”,函数(数据){
数据库事务(功能(tx){
对于(变量i=0;i