0

以下の関数は、常に「挿入されたシリアル: 未定義」を返します。console.logdb.transaction の前にシリアル (数字のみ) を出力すると、なぜこれを行っているのかを理解するのに苦労しています。内部で db.transaction data[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]);
          });
        }
      }
    });
  }
4

1 に答える 1

1

非同期トランザクションが 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]);
        });
      }
    }
  });
}
于 2013-10-11T03:29:43.237 に答える