我正在使用SequelSphere作为我的HTML5客户端数据库。我还使用“更改跟踪器”来跟踪我的应用正在执行的任何插入,更新和删除。当需要同步更改时,跟踪器会完美地报告更改。
问题在于:将数据发送到服务器是异步的,需要一些时间。在发送数据时,我希望应用程序继续工作,更改表中的更多数据,并让更改跟踪器继续跟踪更改。同步完成后,我调用“tracker.clearChanges()”来删除已同步到服务器的更改。但是对“tracker.clearChanges()”的调用将清除所有更改,包括在同步期间添加但尚未同步的更改。
如何调用“clearChanges()”并仅删除同步更改?或者,如何在同步发生时保留跟踪器记录的更改?
谢谢,
比尔怀特答案 0 :(得分:1)
很好的问题。我建议结束先前的更改跟踪器并开始一个新的跟踪器,如下所示:
// Keeps track of trackers
var curTrackerNbr = 0;
var curTracker = null;
var syncTracker = null;
function getChangeTracker() {
return db.changeTrackers.create("orders_tracker_" + curTrackerNbr, ["orders_table", "invoice_table"]);
}
function beginSync() {
// end current tracking, start new one
syncTracker = curTracker;
syncTracker.endTracking();
// creating a tracker automatically turns it on...
curTracker = getChangeTracker();
// Get data to be sync'd
var syncData = syncTracker.getChangedRows();
// Perform sync
syncDataToServer(syncData, onSyncSuccess, onSyncFailure);
}
function onSyncSuccess() {
// remove the syncTracker (for cleaning purposes)
db.changeTrackers.drop(syncTracker.name);
}
function onSyncFailure() {
if (window.confirm("Want to try again?")) {
var syncData = syncTracker.getChangedRows();
syncDataToServer(syncData, onSyncSuccess, onSyncFailure);
}
}
// Now, let's create our first change tracker.
curTracker = getChangeTracker();
我希望上面的代码解释得比我的话更好!
...约翰