如何在同步期间保留DBChangeTracker中的更改?

时间:2012-11-30 00:50:28

标签: javascript html5 synchronization local-storage

我正在使用SequelSphere作为我的HTML5客户端数据库。我还使用“更改跟踪器”来跟踪我的应用正在执行的任何插入,更新和删除。当需要同步更改时,跟踪器会完美地报告更改。

问题在于:将数据发送到服务器是异步的,需要一些时间。在发送数据时,我希望应用程序继续工作,更改表中的更多数据,并让更改跟踪器继续跟踪更改。同步完成后,我调用“tracker.clearChanges()”来删除已同步到服务器的更改。但是对“tracker.clearChanges()”的调用将清除所有更改,包括在同步期间添加但尚未同步的更改。

如何调用“clearChanges()”并仅删除同步更改?或者,如何在同步发生时保留跟踪器记录的更改?

谢谢,

比尔怀特

1 个答案:

答案 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();

我希望上面的代码解释得比我的话更好!

...约翰