我有一个问题,我删除了自动发布,现在我想再次订阅我的收藏品,但它不起作用;(
这是我的两个集合的lib代码:
Events = new Mongo.Collection('events');
Friends = new Mongo.Collection('friends');
然后是我的服务器main.js
import { Meteor } from 'meteor/meteor';
Meteor.startup(() => {
// code to run on server at startup
});
if (Meteor.isServer) {
Meteor.publish("events", function() {
return events.find();
})
Meteor.publish("friends", function() {
return friends.find();
})
}
并在客户端的main.js中输入我的客户端代码
import { Template } from 'meteor/templating';
import { ReactiveVar } from 'meteor/reactive-var';
import './main.html';
Meteor.subscribe("events");
Meteor.subscribe("friends");
我正在运行Meteor 1.4,我的问题是我无法从集合中获取信息
以下是自动发布已经有效的代码
Template.NeuesEvent.events({
"submit .add-event": function(event){
var Name = event.target.name.value;
var Beschreibung = event.target.beschreibung.value;
var Datum = event.target.Datum.value;
var Autor = Meteor.userId();
var eingeladene = [];
$.each($('.FreundeCheckbox:checked'), function(){
eingeladene.push($(this).val());
});
if (Name == "")
{
confirm("Das Event braucht einen Namen ;)")
}
else {
Events.insert({
Name: Name,
Beschreibung: Beschreibung,
erstelltAm: new Date(),
Datum: Datum,
Eingeladen: eingeladene,
Autor: Autor
});
event.target.name.value = "";
event.target.beschreibung.value = "";
FlowRouter.go('/meineEvents');
return false;
}
}
});
和帮助“打印”出来
Template.meineEvents.helpers({
event: function(){
return Events.find({}, {sort: {createdAt: -1}});
}
});
希望你能帮助我修改它以便再次工作谢谢;)
答案 0 :(得分:0)
你必须引用符号,而不是集合名称,如下所示:
if (Meteor.isServer) {
Meteor.publish("events", function() {
return Events.find();
})
Meteor.publish("friends", function() {
return Friends.find();
})
}
编辑:
你说你有这些收藏品:
Events = new Mongo.Collection('events');
Friends = new Mongo.Collection('friends');
他们在哪里定义?它们可供客户端和服务器使用吗?他们在任何名为" / imports"的文件夹下?如果是这样,那么它们不会急切地加载,你需要导出/导入这些符号。
编辑2:
接下来要检查的是查看数据是否已发布。最简单的方法是安装meteortoys:allthings(https://atmospherejs.com/meteortoys/allthings)并查看数据是否已通往客户端。如果没有,那么我会检查以确保您提供的subscribe()行与NeuesEvent模板相关联。
我通常在模板中进行订阅,如下所示:
Template.NeuesEvent.onCreated(function() {
this.subscribe('events');
this.subscribe('friends');
});
...但这取决于您的使用案例。在这里,只要NeuesEvent模板处于活动状态,这些订阅就会处于活动状态。当您切换到其他模板时,订阅将结束。