这是一个非常奇怪的问题。
我在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,没有更新。这是客户端的情况,应该显示更改。
我尝试过Meteor Reset无济于事。任何帮助将不胜感激。
答案 0 :(得分:0)
我弄明白为什么它不起作用。
我没有发布Stacks
集合的每个字段。特别是,不是users
字段。因此,当我尝试使用此行更改集合时,它将失败:
Stacks.update(stackId, {$addToSet: {users: userId}});
然而,Minimongo认识到了这一变化,所以我的查询会错误地告诉我,我已经成功了。一旦服务器拒绝更新,它也会拒绝上面的行,使得两个更改都不会发生。显然,有些人发现MongoDB在失败的交易中缺少错误信息很麻烦。它肯定使这个错误很难找到。
解决方案是将服务器端代码包装在if (Meteor.isServer)
中,以便它只能在服务器端运行。一个不幸的结果是,由于异步性,这些调用不能轻易返回值,但是有相同的解决方法。