gpt4 book ai didi

javascript - MeteorJS 模板不显示数据,不出现

转载 作者:可可西里 更新时间:2023-11-01 09:43:19 27 4
gpt4 key购买 nike

我最初以为我的收藏没有接收到数据,但事实证明我的查询中有一个拼写错误。但是我的数据仍然没有出现在屏幕上。 HTML 模板非常基本,如下所示:

<template name="messages" class=".messages">
{{#each showMessages}}
<blockquote>
<p>{{message}}</p>
</blockquote>
{{/each}}
</template>

它应该只是在我调用 {{> messages}} 时让消息集合出现下面是对应的客户端JS:

Meteor.subscribe("Messages");
Template.messages.helpers({
showMessages: function(){
return Meteor.call("find");
}
});

这是服务器方法:

Meteor.methods({
insert:function(username, message){
var id = Messages.insert({
'message': message,
'user': Meteor.userId(),
'username': username,
'timestamp': new Date()
});

return "success";
},
'find': function(){
return Messages.find({},{sort:{timestamp:-1}}, 20).fetch();
}
});

我是 MeteorJS 的新手,我昨天才学会它,所以它可能是我缺少的一些非常基本的东西,但我已经为此苦苦思索了 2 个小时,但取得了 0 进展。我没有启用不安全或自动发布。这并不是一个可用的产品或任何东西,我用它来自学,所以我知道我在做一些不安全的事情。

最佳答案

在这种情况下,主要是对 Meteor 数据模型的误解。

虽然可以使用方法调用发送数据,但通常您会希望使用 publications and subscriptions向客户端发送数据。它们具有查询实时 的近乎神奇的属性——也就是说,对查询的任何更新都将自动发送到客户端。您拥有的当前代码如果能正常工作,将不会有实时数据。具体问题是 Meteor.call 是异步的,因此您的消息助手将看不到任何内容。

相反,这是您想要做的。在服务器上,您将设置消息集合的发布:

Meteor.publish("someWeirdName", function() {
return Messages.find({},{ sort: { timestamp:-1}, limit: 20});
});

请注意与您的代码的不同之处:没有 fetch(),因为我们想要一个实时游标,而 20 可能是您打算用作限制选项的.请注意,我还称此为 someWeirdName,因为那是 publication 的名称,而不是您将用于在客户端订阅的集合的名称。更详细的解释,你可能想看this post .

然后,在客户端,您只需要以下内容:

Meteor.subscribe("someWeirdName");

Template.messages.helpers({
showMessages: function(){
return Messages.find();
}
});

请注意,您之前对 Meteor.subscribe("Messages") 的调用没有执行任何操作,因为没有名为 Messages 的发布。此外,我们将使用消息的客户端缓存来创建一个游标来显示消息。

此外,所有这些代码都要求您在服务器和客户端上声明以下内容:

Messages = new Mongo.Collection("callMeWhateverYouWant");

另请注意,用于实例化此集合的参数与您在代码中引用集合的方式无关,除非您正在编写 custom publication。 .它只是标识底层数据库中的集合。

关于javascript - MeteorJS 模板不显示数据,不出现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31595993/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com