我正在努力解决一个问题,我将通过一个简单的演示来解释。
People
Collection 中有以下非常简单的文档。
{
"_id" : "vxmLRndHgNocZouJg",
"fname" : "John" ,
"nicks" : [ "Johnny" , "Jo"]
}
现在让我们考虑以下模板。基本上,我会显示用户名和带有输入字段的昵称列表,以添加更多昵称。
<head>
<title>test</title>
</head>
<body>
{{> name}}<br/>
{{> nicks}}
</body>
<template name="name">
<input type="text" value="{{fname}}"/>
</template>
<template name="nicks">
{{#each nicks}}
<div>{{this}}</div>
{{else}}
no nicks yet
{{/each}}
<input type="text" name="nicks"/>
<input type="submit"/>
</template>
我的客户端javascript代码如下:
Template.name.fname = function() {
return People.findOne({"fname" : "John"},{
transform : function(doc) {
return doc.fname;
}
});
}
Template.name.rendered = function() {
console.log('Template "name" rendered!');
}
Template.nicks.nicks = function() {
var john = People.findOne({"fname" : "John"});
if(john) return john.nicks;
}
Template.nicks.events({
'click input[type="submit"]' : function () {
var johnId = People.findOne({"fname" : "John"})._id; // demo code
People.update(johnId,{
$addToSet : {
nicks : $('input[name="nicks"]').val()
}
})
}
});
我的问题是,在添加昵称(nicks
文档中的字段更新)后,模板name
被重新渲染(我知道是因为我 console.log 它)。当我查询People
集合以提供name
模板数据时,我使用transform
选项,因此nicks
字段的更改不应影响name
模板产生影响。
Meteor 文档支持这一点:
游标是一种反应式数据源。当您第一次在反应式计算(例如,模板或自动运行)中使用 fetch、map 或 forEach 检索游标的文档时,Meteor 将注册对基础数据的依赖关系。任何更改游标中文档的集合都会触发重新计算。
name
那么为什么要重新渲染模板呢?