说我有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的结构)来获取反馈数组中匹配索引的值?
答案 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;
});