鉴于此哈希
a = {
foo : { ... },
bar : { ... },
zap : { ... }
}
我想迭代它,但由于密钥不同,我不知道如何在 Mustache.js
输出看起来像 foo :(此处的内容)
答案 0 :(得分:4)
如果您知道要尝试检索的嵌套对象中的键,则可以使用函数。
请参阅:http://jsfiddle.net/jimschubert/zPWDJ/
JS:
$(function() {
var names = {
"a": [
{"foo": { "name": "foo name"}},
{"bar": { "name": "bar name"}},
{"zap": { "name": "zap name"}}
],
"n": function() {
var self = this;
var n = "";
Object.keys(self).forEach(function(k, v) {
if (typeof self[k] == "object") {
if(!n) n = self[k]["name"];
}
});
return n;
}
};
var template = $('#template').html();
var out = $('#output');
var html = Mustache.to_html(template, names);
console.log(html);
out.html(html);
});
HTML:
<script id="template" class="template" type="text/x-mustache">
{{#a}}
<p>{{n}}</p>
{{/a}}
</script>
<h1>Output</h1>
<div id="output">
</div>
这当然假设您的数据是一个对象数组(您的帖子中的a
可能是更大数组的一个键,也许?)如果您没有数组,我看不到为什么你不能为一个对象调整它,并为你正在寻找的每个键的任何属性做一个getter函数。