如何使用Handlebars.js获取索引处的数组值?

时间:2013-08-11 05:03:12

标签: handlebars.js

说我有JSON:

{
userinput: [
    {name: "brian", "value": "i like pies"},
    {name: "susan", "value": "memes are stupid"}
],
feedback: [
    {value: "i also like pies"},
    {value: "null"}
]
}

我正试着画一张这样的桌子:

name ..... | input ......   | feedback
-----------|----------------|-----------------
brian      | I like pies    | I also like pies
susan      | mems are stupid| null

虽然我认识到将反馈作为“用户输入”的价值会更好,但我所做的并不是那样......

我正试图在{{#each userinput}}`中获取反馈索引,例如

{{#each userinput}}
<td>{{name}}</td><td>{{value}}</td><td>{{../feedback[@index].value}}</td>
{{/each}}

但当然{{../feedback[@index].value}}不起作用。

什么是最好的方法(不改变json的结构)来获取反馈数组中匹配索引的值?

2 个答案:

答案 0 :(得分:14)

这可以使用the lookup helper

来完成
  

fromPath助手允许使用Handlebars变量进行动态参数解析。这对于解析数组索引的值非常有用。

所以你的例子的模板看起来像这样:

lookup

答案 1 :(得分:3)

我想你必须为此编写一个块助手,因为看起来@index只能用作独立的。

我修改了"list" example,以允许这样的模板:"{{#list userinput feedback}}<td>{{name}}</td><td>{{value}}</td><td>{{@feedback.value}}</td>{{/list}}"。实现是这样的,接受两个参数“输入”和“反馈”(加上标准的“选项”)。

Handlebars.registerHelper('list', function(input, feedback, options) {
  var out = "", data;

  // iterate over the input
  for (var i=0; i<input.length; i++) {
    if (options.data) {
      data = Handlebars.createFrame(options.data || {});

      // add "feedback" item to the current frame's data
      data.feedback = feedback[i];
    }

    out += "<tr>" + options.fn(input[i], { data: data }) + "</tr>";
  }

  return out;
});

Here's the Fiddle.