用胡子迭代JSON数组

时间:2013-06-24 19:44:30

标签: json mustache

我是Mustache的新手,请耐心等待我:)

我的JSON中有一个数组

"prop":{"brands":["nike","adidas","puma"]}

如果我有这样的模板

{{#prop}}
 <b>{{brands}}</b>
{{prop}}

我希望得到类似的内容:

<b>nike</b>
<b>adidas</b>
<b>puma</b>

我理解数组中的元素不是散列键值对,但是我想知道胡子中是否还有迭代我可以遍历这些元素。

谢谢!

3 个答案:

答案 0 :(得分:34)

这是一个工作小提琴:http://jsfiddle.net/Qa4UX/

基本上,您需要遍历品牌阵列。 由于你的数组是原始的并且里面没有对象,你必须像这样引用每个字符串:

{{#props}}
  <ul>
  {{#brands}}
    <li>
    {{#.}}
        <b>{{.}}</b>
    {{/.}}
    </li>
  {{/brands}}
  </ul>
{{/props}}

您还可以在此处找到更多示例:https://github.com/janl/mustache.js#mustachejs---logic-less-mustache-templates-with-javascript

答案 1 :(得分:18)

这有效

{{#json.props.brands}}
<h1>{{.}}</h1>
{{/json.props.brands}}

{{.}}循环遍历字符串数组时,可以使用.来引用列表中的当前项。

答案 2 :(得分:4)

小胡子是无逻辑的,所以在其中编写自己的迭代/循环是不可能的。虽然很容易转换你的JSON。例如:

var json = '{"prop":{"brands":["nike","adidas","puma"]}}';
var obj = JSON.parse(json);
var data = {brands: obj.prop['brands'].map(function(x){ return {name: x}; })};

为您提供一个data变量,该变量适用于模板:

{{#brands}}
  <b>{{name}}</b>
{{/brands}}