我有问题。我的数据库中有一组文档,我想根据是否设置了与该文档对应的会话变量来显示每个文档。
为了说明我的问题,让我举一个简化的例子。
Meteor.myTemplate.helpers({
stuff: [
{name: 'item1'},
{name: 'item2'}
{name, 'item3'},
{name: 'item4'},
{name: 'item5'}
],
isActive: function (itemName) {
return Session.get(itemName + 'IsActive');
}
});
现在,我想做的是:
{{#each stuff}}
{{#if isActive {{name}} }}
{{> someTemplate}}
{{/if}}
{{/each}}
但由于不支持这样的嵌套标签,我无法做到这一点。我正在寻找一种方法来实现这一目标,而不必写:
{{if isActive 'item1'}}{{> someTemplate}}{{/if}}
{{if isActive 'item2'}}{{> someTemplate}}{{/if}}
{{if isActive 'item3'}}{{> someTemplate}}{{/if}}
{{if isActive 'item4'}}{{> someTemplate}}{{/if}}
{{if isActive 'item5'}}{{> someTemplate}}{{/if}}
如果数据是静态的,如上例所示(而不是来自数据库游标),这是可能的,但它在任何情况下都不实用,特别是对于很多项目。此外,这种风格可能会让每个程序员都感到畏缩。
答案 0 :(得分:3)
由于isActive的上下文是stuff
,因此助手可以使用this.name
:
Template.myTemplate.helpers({
isActive: function(itemName) {
return Session.get(this.name + 'IsActive');
}
});
您的模板如下所示:
{{#each stuff}}
{{#if isActive}}
{{> someTemplate}}
{{/if}}
{{/each}}