Backbone.js使用本地WebSockets同步

3
我试图重写默认的Backbone.sync函数,使用WebSocket进行同步。到目前为止,我已成功地使用下面的代码向服务器发送了一个fetch请求,但我不知道如何捕获响应。
我看到有人建议每次重置sockets的onmessage事件处理程序,但我不能不考虑这可能会导致响应失去同步,如果一次请求大量数据(如果一个请求需要很长时间来响应)。
是否有任何示例可以实现我正在尝试的内容?
var app = app || {};

function fnSync (sMethod, oModel, oOptions) {
    var bSuccess,
        sResponse;

    bSuccess = false;

    switch (sMethod) {
        case "read":
            if (oModel.id !== undefined) {
                app.socket.send(JSON.stringify({
                    "method": "get",
                    "url": oModel.url,
                    "id": oModel.get("_id")
                }));
            } else {
                app.socket.send(JSON.stringify({
                    "method": "get",
                    "url": oModel.url
                }));
            }
            bSuccess = true;
            break;

        default:
            throw "Backbone.sync doesn't know how to " + sMethod;
            bSuccess = false;
            break;
    }

    (bSuccess) ? oOptions.success() : oOptions.error();
}

(function () {

    app.socket = new WebSocket("ws://localhost:3001");
    app.socket.onopen = function () {
        Backbone.sync = fnSync;

        app.router = new app.Router();
        Backbone.history.start();
    }

    app.socket.onmessage = function (oMessage) {
        //console.log("Socket message", oMessage.data);
    }

})();
2个回答

1
你可以查看Backbone.WS项目,以便在本地WebSocket上使用Backbone资源。

0
我们使用的技术涉及在 socket.onmessage 处理程序中使用 Backbone-relationalModel.findOrCreate({id: response.id})来调度更新,当我们找到它时,使用简单的 model.set() 进行更新。
在没有 ID 的情况下,我们使用仅客户端临时 ID,API 被设计为忽略并原样返回,以便我们可以区分和跟踪响应。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接