我在Meteor中创建了一个基于位置的聊天应用。现在,我只想呈现用户区域中的聊天消息。TheRegion.region变量被一个HTML5地理定位请求填充。
Template.locationchat.helpers({
messages: function () {
return Messages.find({location: TheRegion.region});
}
});这段代码的问题是,当调用此助手时,TheRegion.region变量仍然是null。有没有一种方法可以在地理位置函数的回调中运行助手?或者在变量有值时运行模板助手?
发布于 2015-05-19 15:37:44
那是因为你的变量不是反应性的。
在onCreated中:
TheRegion = new ReactiveDict();
TheRegion.set('region',undefined);现在,区域在到达助手时总是存在的&当值发生变化时,您的助手将重新运行。
发布于 2015-05-19 15:24:36
我经常在Meteor中发现,如果你在等待一个变量,你所需要的就是一个if子句来保护自己。
试试这个:
Template.locationchat.helpers({
messages: function () {
if(TheRegion.region)
return Messages.find({location: TheRegion.region});
}
});这感觉不自然,但通常是有效的。试试看。
https://stackoverflow.com/questions/30329079
复制相似问题