2

在客户端我有这个:

var Coll1 = new Meteor.Collection('myCollection1');
var Coll2 = new Meteor.Collection('myCollection2');

var handle1 = null;
Deps.autorun(function () {
    var temp = Session.get('id');
    if (id) handle1 = Meteor.subscribe('myCollection1', id);
};

var handle2 = null;
Deps.autorun(function () {
    var temp = Session.get('id');
    if (id) handle2 = Meteor.subscribe('myCollection2', id);
};

在模板代码的其他地方,我这样做(当用户单击 DOM 元素时):

Coll1.insert({name: 'new element1');
Coll2.insert({name: 'new element2');

上面的代码不会在客户端触发 Coll1 和 Coll2 的更新(但在服务器上很好)。如果我刷新浏览器,就会执行更新,即客户端与服务器同步并显示新元素。

我错过了什么?

4

1 回答 1

3

你似乎没有在这里改变反应变量Session.get('id')

Deps.autorun 像这样工作

Deps.autorun(function(){
  var iAmReactive = Session.get('iAmReactive');
  <subscribe to something using iAmReactive>
});

如果会话值iAmReactive发生变化,则重新运行订阅

这也可能是这样的

Deps.autorun(function(){
  var iAmAReactiveQuery = Collection.find({<query>});
  <subscribe to something>
});

在这种情况下,如果查询中的数据发生更改,则重新运行订阅


发布功能是什么样的?您确定使用提供的 id 参数返回插入的项目吗?

于 2013-04-26T15:28:20.177 回答