如何嵌套空格键标签?

时间:2015-05-18 23:24:59

标签: javascript meteor spacebars meteor-helper

我有问题。我的数据库中有一组文档,我想根据是否设置了与该文档对应的会话变量来显示每个文档。

为了说明我的问题,让我举一个简化的例子。

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}}

如果数据是静态的,如上例所示(而不是来自数据库游标),这是可能的,但它在任何情况下都不实用,特别是对于很多项目。此外,这种风格可能会让每个程序员都感到畏缩。

1 个答案:

答案 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}}