Meteor DDP:如何在将新文档添加到集合时收到通知

时间:2014-07-30 19:55:19

标签: javascript meteor ddp

我正在编写一个软件,通过DDP连接到Meteor服务器以读取数据。

我面临的问题是找出如何区分添加到集合中的新文档和获取已有文档的通知。

当我第一次连接到服务器时,我收到一系列added消息来填充clientide集合。我不知道如何区分这些消息,以及稍后出现的消息,表明实时添加了新文档。当DDP客户端需要重新连接到服务器时,这会变得更糟,此时所有当前文档都会再次作为added消息发送。

2 个答案:

答案 0 :(得分:10)

我花了一些时间才真正意识到,但这正是low-level publish API设计的那种东西。阅读&#34中的部分;或者,发布功能可以..."向下,应该非常清楚如何只发送added条消息来获取真正的新文档。或者提供一个简单的例子:

服务器和客户端:

MyData = new Meteor.Collection("mydata");

客户端:

Meteor.subscribe('myPub', myFilter);

服务器:

Meteor.publish('myPub', function(filter) {
  var self = this;
  var initializing = true;

  var handle = MyData.find(filter).observeChanges({
    added: function (id, fields) {
      if (!initializing)
        self.added("mydata", id, fields);
    },
    changed: function(id, fields) {
      self.changed("mydata", id, fields);
    },
    removed: function (id) {
      self.removed("mydata", id);
    }
  });
  initializing = false;
  self.ready();

  self.onStop(function () {
    handle.stop();  // v. important to stop the observer when the subscription is stopped to avoid it running forever!
  });
});

<强>更新

这是如此根本,我实际上已经写了blog post

答案 1 :(得分:3)

我过去遇到过这个问题并找到了解决方案。在第一次渲染时设置变量并在初始观察后更改变量 - 例如:

var initializing = true;

var handle = Collection.find().observe({
  added: function (item) {
    if (!initializing)
        // do stuff with newly added items, this check skips the first run
  }
});

initializing = false;