gpt4 book ai didi

javascript:如何保持事务(WebSql)事件

转载 作者:行者123 更新时间:2023-11-28 02:16:06 24 4
gpt4 key购买 nike

我有一个 Worker,我想在其中执行 sql 查询。但是,这就是我的问题,我希望所有这些查询都在同一事务中执行。这就是我现在的(不工作的) worker 的方式:

db = openDatabase("WorkerFoo", "", "", 1);

if (db) {
db.transaction(function (tx) {
self.onmessage = function(e) {
tx.executeSql(e.data, [], function(tx, rs){
self.postMessage(rs.rows.item(0)) ;
}) ;
};
}) ;
}
else {
self.postMessage('No WebSql support in Worker') ;
}

但是,这样做没有任何反应(没有错误)。有什么建议如何解决这个问题吗?

我的另一个(相关)问题是,如果查询阻塞了 UI 线程,因为查询很重并且需要几秒钟,那么在 Worker 中执行查询会解决这个问题吗?

非常感谢!

最佳答案

回答您的问题:

  • 查询不应阻塞 UI 线程,即使不在 Web Worker 中执行,因为它是异步的(假设目标计算机具有足够的多线程能力)。 JavaScript 在非阻塞异步 IO 上蓬勃发展。

  • 例如,您可以将 SQL 代码本身传递给工作线程,并拥有 transactionStarttransactionEnd 消息,并且仅在收到transactionEnd

注意,WebSQL 规范是 no longer under work .

您可能需要考虑IndexedDB ,它的方法也返回而不阻塞调用线程。 (同样,不需要 Web Workers,但是如果您愿意,它有一个同步版本,您可以将其与 WebWorkers 一起使用(但我认为还没有人实现)。

祝你好运!

关于javascript:如何保持事务(WebSql)事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16384899/

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