我一直在广泛使用 Firebase,但仍然只面临一个真正的问题:根据我的经验,onDisconnect 并不是 100% 可靠的。
如果您在没有先关闭窗口的情况下关闭了计算机,或者关闭了浏览器,那么您有时会让“垃圾收集器”执行 onDisconnect,有时则不会。
我的问题如下:我只是暂时不使用/.connected,我基本上使用一个简单的
userRef.set('status', 1);
userRef.onDisconnect().update({ 'status' : 0 });
这种方法有什么问题吗?我们是否同意更新参数在执行该行时而不是在窗口卸载之前传递给服务器?
注意:我碰巧尝试保持多窗口状态,如果另一个窗口关闭,则使用以下方法将状态保持为 1:
userRef.child('status').on('value', function(snap) {
if (snap.val() != 1) {
userRef.set('status', 1);
}
});
我不知道这有什么关系,但是...
我的解决方案:事实上,我刚刚错过了您了解到 onDisconnect 仅触发一次的部分。要获得持久的 onDisconnect,您需要实现基本的持久性。
Helpers.onConnected = function(callback) {
var connectedRef = lm.newFirebase('.info/connected');
var fn = connectedRef.on('value', function(snap) {
if (snap.val() === true) {
if (callback) callback();
}
});
var returned = {};
returned.cancel = function() {
connectedRef.off('value', fn);
};
return returned;
};
简单用例:
this._onConnected = lm.helpers.onConnected(function() {
this.firebase.onDisconnect().update({ 'tu': 0 });
}.bind(this));
然后取消:
if (this._onConnected) this._onConnected.cancel();
this.firebase.onDisconnect().cancel();