Javascript “装载和等待”;“全球”;流星订阅
以下是我的设想: 我有一个布局模板,需要检查用户是否至少属于一个团队。如果不是,则在整个站点上显示一个div。用户只能看到他们所属的团队,因此我创建了一个简单的出版物,可以正常工作:(代码示例是CoffeeScript) 这非常有效,而且控制台中的Teams.find().fetch()会给出预期的结果 但是,如果我把这段代码放在Template.layout.rendered中,它就不起作用了Javascript “装载和等待”;“全球”;流星订阅,javascript,meteor,coffeescript,Javascript,Meteor,Coffeescript,以下是我的设想: 我有一个布局模板,需要检查用户是否至少属于一个团队。如果不是,则在整个站点上显示一个div。用户只能看到他们所属的团队,因此我创建了一个简单的出版物,可以正常工作:(代码示例是CoffeeScript) 这非常有效,而且控制台中的Teams.find().fetch()会给出预期的结果 但是,如果我把这段代码放在Template.layout.rendered中,它就不起作用了 Template.layout.rendered = -> teams = Teams.f
Template.layout.rendered = ->
teams = Teams.find().fetch()
hasTeams = teams.length > 0
if !hasTeams
...do stuff..
显然,这不起作用,因为团队查找是异步的,在需要做出决策时没有加载。对于一个普通的模板/页面,我只需要使用IronRouter waitOn(),但是我在布局上做什么呢
我可以在我的路由器上做一个waitOn,但是由于数据是“全局的”,并且将在任何地方使用,而且因为用户可以深入链接到整个站点,所以我不想在每条路由上都添加waitOn
那么正确的模式是什么呢?如何让meteor客户端加载全局数据并在运行路由之前等待数据?更多思考和搜索就在这里找到了答案,因此: 我更改了路由器。配置为:
Router.configure
layoutTemplate: 'layout'
waitOn: ->
return [
Meteor.subscribe('teams')
]
可以向返回数组添加多个订阅,我相信它将等待所有订阅 我与iron router在两种不同的出版物上与waitOn订阅聊天时遇到了类似的问题
Meteor.subscribe('chats')
只有当我切换以下发布块的位置时,它才会让我看到路由上的任何数据。以下是这两种方法的正确顺序
Meteor.publish("chats", function () {
return Chats.find();
});
Meteor.publish("chats", function(id) {
return Chats.find({eventRoom: id});
});
Meteor.publish("chats", function () {
return Chats.find();
});
Meteor.publish("chats", function(id) {
return Chats.find({eventRoom: id});
});