gpt4 book ai didi

jquery - 获取 Handlebars 上的 key

转载 作者:行者123 更新时间:2023-12-01 04:19:38 25 4
gpt4 key购买 nike

var data = {
"name": "Jack",
"eventlist": {
"1": {
"title": "Title1"

},
"3": {
"title": "Title2",

}
}
};

HTML

<div class="container">
<ul>
<script id="list_template" type="text/x-handlebars-template">
<li>

</li>
</script>
</ul>
</div>

我正在使用handlebar js进行模板化。我想知道如何迭代数据对象并打印“标题”以及相应的键“1”,“3”

最佳答案

您可以注册一个类似#each 的专用 block 帮助程序,它将散列/对象上下文的键与循环的“内部”上下文一起传递:

// based on the `#each` helper, requires jQuery (for jQuery.extend)
Handlebars.registerHelper('each_hash', function(context, options) {
var fn = options.fn, inverse = options.inverse;
var ret = "";

if(typeof context === "object") {
for(var key in context) {
if(context.hasOwnProperty(key)) {
// clone the context so it's not
// modified by the template-engine when
// setting "_key"
var ctx = jQuery.extend(
{"_key":key},
context[key]);

ret = ret + fn(ctx);
}
}
} else {
ret = inverse(this);
}
return ret;
});

当然,在渲染模板之前需要注册助手。

然后在您的模板中,您可以使用 _key 占位符引用 key :

<script id="list_template" type="text/x-handlebars-template">
{{#each_hash eventlist}}
<li>
<span class="evl-key">{{_key}}</span> -
<span class="evl-title">{{title}}</span>
</li>
{{/each_hash}}
</script>

然后像任何其他 Handlebars 模板一样渲染模板:

var source = $("#list_template").html();
var template = Handlebars.compile(source);

var html = template(data);

$("div.container ul").append(html);

关于jquery - 获取 Handlebars 上的 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12032851/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com