3

我的 HTML:

<template name="foo">
    {{#each category}}
         {{#if this.custom}}
              {{> someTemplateName}}
         {{else}}
              {{> generic}}
         {{/if}}
     {{/each}}
 </template

如何将一些值返回给“someTemplateName”,以便我可以根据#each 语句中的对象切换模板。

 Template.foo.someTemplateName = function () {
      return A_TEMPLATE_NAME
 }

谢谢。

4

2 回答 2

3

正确的语法如下:

JS

Template.foo.helpers({
  someTemplate:function () {
    return Template.someTemplate;
  }
});

HTML

<template name="someTemplate">
  <p>SOME TEMPLATE</p>
</template>

它实际上不是您操作的名称,而是位于变量 name 下的模板对象Template.myTemplate

如果要操作模板名称,请尝试UI.dynamic

HTML

<template name="foo">
  {{> UI.dynamic template=someTemplateName}}
</template>

JS

Template.foo.helpers({
  someTemplateName:function () {
    return "someTemplate";
  }
});
于 2014-10-02T20:56:36.267 回答
3

解决方案实际上非常简单。

 <template name="foo">
     {{#each category}}
        {{#if this.custom}}
          {{> someTemplateName}}
        {{else}}
          {{> generic}}
       {{/if}}
     {{/each}}
 </template>

我返回一个帮手:

Template.foo.someTemplateName = function () {
    return Template[this.name];
}

this.name 来自 `{{#each}}' 上下文。

于 2014-10-02T21:11:14.083 回答