首页 > 解决方案 > 如何遍历 JSRender 中的对象数组?

问题描述

我只能从 JSRender 中的对象数组中渲染第一个对象。如何迭代所有对象?

{{for #data}}仅显示data数组中的第一个对象。

var data = [{
    "id": "15",
    "name": "Jane Doe",
    "value": null
}, {
    "id": "6",
    "name": "John Smith",
    "value": "123-456-7890"
}, {
    "id": "6",
    "name": null,
    "value": "223-456-7890"
}]

代码笔: https ://codepen.io/ryanmac/pen/ZEWQMNV

HTML:

<div id="result"></div>

<script id="theTmpl" type="text/x-jsrender">
  
<table><tbody>
{{for #data}}
  <tr><td><b>name:</b> {{:name}}</td><td>{{:value}}</td></tr>
{{/for}}
</tbody></table>

JS:

var data = [{
    "id": "15",
    "name": "Jane Doe",
    "value": null
}, {
    "id": "6",
    "name": "John Smith",
    "value": "123-456-7890"
}, {
    "id": "6",
    "name": null,
    "value": "223-456-7890"
}];
var template = $.templates("#theTmpl");

var htmlOutput = template.render(data);

$("#result").html(htmlOutput);

输出:

姓名:简·多伊

其他行去哪儿了?我该如何调试呢?

标签: javascriptjsrenderjsviews

解决方案


这是因为你没有关闭<script>标签

<script id="theTmpl" type="text/x-jsrender">
 ....
</script>

推荐阅读