我是Mustache的新手,请耐心等待我:)
我的JSON中有一个数组
"prop":{"brands":["nike","adidas","puma"]}
如果我有这样的模板
{{#prop}}
<b>{{brands}}</b>
{{prop}}
我希望得到类似的内容:
<b>nike</b>
<b>adidas</b>
<b>puma</b>
我理解数组中的元素不是散列键值对,但是我想知道胡子中是否还有迭代我可以遍历这些元素。
谢谢!
答案 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}}