2

我可能使用了错误的词来描述我的问题,所以这是我正在使用的(简化的)代码。

我很高兴学习一种更好的方法来做到这一点,但我目前正在尝试做的是传递{{assigneeId}}给名为agentIs. 问题是我找不到传递值的正确方法。

<template name="ticket_list">
  {{#each tickets}}
    {{> ticket}}
  {{/each}}
</template>

<template name="ticket">
  <h3>{{title}}</h3>
  <p>{{assigneeId}}</p>
  {{> ticket_footer}}
</template>

<template name="ticket_footer">
  {{> agent_list}}
</template>

<template name="agent_list">
  <!-- {{assigneeId}} exists here as expected -->
  assigneeId: {{assigneeId}}
  <label for="agent">Agent</label>
  <select id="agent" name="agent">
    {{#each agents}}
      <!-- value passed: "{{assigneeId}}" -->
      <option value="{{_id}}" {{#if agentIs "{{assigneeId}}"}}selected{{/if}}>
        {{profile.name}}
      </option>
      <!-- value passed: undefined -->
      <option value="{{_id}}" {{#if agentIs assigneeId}}selected{{/if}}>
        {{profile.name}}
      </option>
      <!-- value passed: JSON.parse error -->
      <option value="{{_id}}" {{#if agentIs {{assigneeId}}}}selected{{/if}}>
        {{profile.name}}
      </option>
    {{/each}}
  </select>
</template>
Template.agent_list.agents = function() {
  return Meteor.users.find({"profile.is_agent": true}, {sort: {profile: 1}});
}

Template.agent_list.agentIs = function(assigneeId) {
  return this._id === assigneeId;
};
4

1 回答 1

3

正确的语法是:

{{#if agentIs ../assigneeId}}selected{{/if}}

{{#each agent}} 块助手在模板上下文树中引入了一个新级别(新上下文对应于当前代理),这就是为什么您需要从一个级别“返回”以正确引用前一个上下文的原因assigneeId 驻留。

于 2013-07-30T02:05:05.213 回答