首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >变量不再可以在web sql事务中访问吗?

变量不再可以在web sql事务中访问吗?
EN

Stack Overflow用户
提问于 2013-10-10 17:42:23
回答 1查看 465关注 0票数 0

下面的函数总是返回‘插入序列:未定义’。我很难理解它为什么要这么做,如果我在console.log之前使用db.transaction,那么它会输出一个序列(只是一个数字)。为什么在db.transaction数据中突然没有定义?

代码语言:javascript
运行
复制
  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]);
          });
        }
      }
    });
  }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-10-11 03:29:43

异步事务位于for循环中,这会导致创建许多并行事务而不重用它们。将事务放到循环之外,并对所有请求重用事务。

代码语言:javascript
运行
复制
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]);
        });
      }
    }
  });
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19302620

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档