2

这是一个非常奇怪的问题。

我正在运行 a cursor.observe()Tracker.autorun()但只有在刷新页面时才会发生更改。这是重要的代码:

客户端

Tracker.autorun(function (){
  var initializing = true;
  Links.find().observe({
    added: function(doc){
        var parents = Links.find({stacks: {$exists: true, $not: {$size: 0}}});
        //Find the parent of this item with a stack array
        if(!initializing){
            _.each(parents.fetch(), function(parentDoc){
                _.each(parentDoc.stacks, function (stackId){

                    //The troublesome server call
                    Meteor.call("addLinksFromDirToStack", 
                      stackId, parentDoc.shared[0].id, parentDoc._id);

                });
              });
          }
      initializing = false;
    }
  });
});

服务器端

Meteor.methods({
  addLinksFromDirToStack: function(stackId, userId, dirId){
        var stack = Stacks.findOne(stackId);
        if (stack){
            var webArray = stack.webArray;
            webArrayFiller(dirId, webArray);
            Stacks.update(stackId, {$set: {webArray: webArray}});
            Stacks.update(stackId, {$addToSet: {users: userId}});
        }
        // NOTE: IF I QUERY THE STACKS COLLECTION HERE, I SEE THE CHANGES
    }
});

webArrayFiller = function(dirId, webArray){
    //Update array
}

如上所述,如果我在更新后直接查询 Stacks 集合,则更改会反映在数据库中。但是,从 Mongo Shell 查询,我仍然看到旧的 Stack,没有更新。这是客户端的情况,应该显示更改。

我试过流星重置无济于事。任何帮助将非常感激。

4

1 回答 1

0

我弄清楚为什么它不起作用。

我并没有出版该系列的每个领域Stacks。特别是,不是users领域。因此,当我尝试使用这一行更改集合时,它会失败:

Stacks.update(stackId, {$addToSet: {users: userId}});

然而,Minimongo 认识到了这个变化,所以我的查询会错误地告诉我我已经成功了。一旦服务器拒绝了更新,它也会直接拒绝上面的行,使这两个更改都不会发生。显然,有些人发现 MongoDB 在失败的事务中缺少错误消息很麻烦。这肯定使这个错误很难找到。

解决方案是将服务器端代码包装在 a 中if (Meteor.isServer),以便它只能在服务器端运行。一个不幸的结果是,由于异步性,这些调用不能轻易地返回值,但有一些解决方法。

于 2015-07-24T19:02:58.760 回答