在我非常简单的 meteor 项目中,客户端辅助函数被调用了两次。
项目中的三个文件是:
websites.js:作为模型类的 MongoDB 集合
image_share.html:包含 Blaze 模板
image_share.js:包含 blaze 模板的辅助函数
Helper 函数 webSites 被调用了两次,而本应被调用一次。
尽管我在 Meteor.startup() 填充了 mongoDB 集合 Websites,但该集合在第一次调用时显示 0 个项目,在第二个电话。
那么问题来了,为什么helper函数在Meteor.startup()之前被调用,为什么会被调用两次,并且在不同的调用中返回不同的值?
完整代码如下:
网站.js:
export const Websites = new Mongo.Collection("websites");
Meteor.startup(function(){
if(Meteor.isServer){
Websites.remove({});
for(i = 0; i < 5; i++)
Websites.insert({
"x": "this is a sample text"
});
}
});
image_share.html:
<head> <title>courseraNewsAgg</title></head>
<body>
{{> websiteList}}
</body>
<template name="websiteList">
<h2 >Items: </h2>
{{#each webSites}}
<div>
{{x}}
</div>
{{/each}}
</template>
image_share.js:
import { Template } from 'meteor/templating';
import { ReactiveVar } from 'meteor/reactive-var';
import {Websites} from "/import/websites.js";
Template.websiteList.helpers({
webSites: function(){
console.log("list size = " + Websites.find().count());
return Websites.find();
}
});
最佳答案
实际上,是您的日志记录行导致帮助程序重新运行。
注意:我不想在这里深入细节,因为这是一个初学者级别的问题,但我仍然会尽量做到精确。
它运行了两次,因为您在第一次渲染模板时没有数据。它与服务器上的 Meteor.startup() 无关。
Meteor 中的模板助手是 reactive computations 。这些计算正在跟踪 react 性数据源,例如数据库查询游标(例如,Websites.find().count() 返回的游标。
当计算中的某些内容发生变化(无效)时,计算将重新运行。这是通过使用 Meteor 的 Tracker mechanism 实现的。在幕后。
在页面加载时,您本地客户端的集合是空的。客户端订阅它们(或者,如果您使用的是 autopublish 包,订阅会自动为您创建 - 对于生产应用程序来说并不是一件好事)。
这是第一次呈现模板时,因此助手运行时会返回一组空记录,但由于您在那里有一个响应式(Reactive)数据源(count()调用),它对其进行监控。
您的服务器可能一直都有数据,只是您的客户端尚不可用。
一段时间后,数据从订阅到达,集合被更新并注意到被跟踪的计数现在不同了,因此计算无效并重新运行帮助程序。这次客户已经有了数据,结果是一组 5 个文档。它仍然监视光标的变化。
如果您以某种方式(例如,通过 Meteor 方法调用)添加新记录或删除服务器上的现有记录,发布将知道它并将新数据发送到客户端。
然后客户端的集合将被更新并使 count 计算无效,这将使助手中的计算无效并导致助手重新运行并再次查询集合。
在这种情况下,Blaze(模板库)将监控游标本身(通过观察它)并且只会以更精细的方式执行所需的更改。
关于javascript - Meteor 辅助函数总是在 Meteor.startup() 之前被调用,并且被调用两次而不是一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40079073/
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我将应用程序升级到Rails4,一切正常。我可以登录并转到我的编辑页面。也更新了观点。使用标准View时,用户会更新。但是当我添加例如字段:name时,它不会在表单中更新。使用devise3.1.1和gem'protected_attributes'我需要在设备或数据库上运行某种更新命令吗?我也搜索过这个地方,找到了许多不同的解决方案,但没有一个会更新我的用户字段。我没有添加任何自定义字段。 最佳答案 如果您想允许额外的参数,您可以在ApplicationController中使用beforefilter,因为Rails4将参数
我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser
我正在尝试用ruby中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了
我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我需要一些关于TDD概念的帮助。假设我有以下代码defexecute(command)casecommandwhen"c"create_new_characterwhen"i"display_inventoryendenddefcreate_new_character#dostufftocreatenewcharacterenddefdisplay_inventory#dostufftodisplayinventoryend现在我不确定要为什么编写单元测试。如果我为execute方法编写单元测试,那不是几乎涵盖了我对create_new_character和display_invent