gpt4 book ai didi

javascript - 同步模式下的WebSQL...可能吗?

转载 作者:行者123 更新时间:2023-11-28 10:18:03 26 4
gpt4 key购买 nike

我开始使用 HTML5 和 WebSQL,但很快就遇到了一个问题:所有数据库调用都是异步的。我来自 PHP 编程,所有的调用都是同步的,我对异步的东西感到困惑。

基本上,我打开数据库并运行一个查询,该查询使用我通过 GET 传递到页面的 id 参数(即 http://myserver.com/mypage.html?id=123 )。我需要 globalResult 中的结果:

id=window.location.search.substring(1).split('=')[1];
db=openDatabase("testDB", "1.0", "Test Database", 10000000);

db.transaction(function(tx)
{
tx.executeSql("SELECT * FROM testTable WHERE id="+id,[],successCB,errorCB);
});

function errorCB(tx,err)
{
alert("Error processing SQL: "+err);
}

function successCB(tx,result)
{
globalResult=result.rows.item(0)['description'];
}

...Javascript code which needs globalResult to be set...

现在,由于查询是异步的,解释器在得到结果之前就开始执行其余的代码,当然这是行不通的。

是否有同步运行查询的技巧,或者使用回调函数的技术来解决这个问题?

提前谢谢大家:)

最佳答案

我实际上从来没有遇到过和你一样的问题,我的WebSQL实现示例:

var projectName = {};
projectName.webdb = {};
projectName.webdb.db = null;
projectName.webdb.open = function() {
projectName.webdb.db = openDatabase('Database Name', '1.0', 'description', 10 * 1024 * 1024);
}
projectName.webdb.onError = function(tx, e) {alert('Database Error: ' + e.message );}
projectName.webdb.onSuccess = function(tx, r) {}
projectName.webdb.getPeopleForExample = function() {
projectName.webdb.db.transaction(function(tx) {
tx.executeSql('SELECT * FROM people WHERE id=23', [], loadPeople, projectName.webdb.onError);
});
}

function loadPeople(tx, rs) {
for (var i=0; i < rs.rows.length; i++) {
var name = rs.rows.item(i).name;
var email = rs.rows.item(i).email;
// now you do whatever you want with the data..
}
}

然后从我刚刚调用的过程代码中的任何地方
projectName.webdb.getPeopleForExample();

我想您会从代码示例中得到这个想法:)

关于javascript - 同步模式下的WebSQL...可能吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6141568/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com