gpt4 book ai didi

javascript - 循环内的 Handlebars 助手

转载 作者:行者123 更新时间:2023-11-29 21:49:19 29 4
gpt4 key购买 nike

模板

   <script id='handlebar-template'>
{{#each tags}}
{{#isObject this}}
<span>Object</span>
{{else}}
<span>String</span>
{{/isObject}}
{{/each}}
</script>

脚本

 <script>
Handlebars.registerHelper('isObject', function(o) {
return typeof o === "object";
});

var props = {"tags": ["Google"]}
var html = $("#handlebar-template").html();
var template = Handlebars.compile(html);
console.log(template(props));
</script>

预期输出

<span>String</span>

实际输出

false

else block 被执行但输出返回是false而不是 <span>String</span> .

最佳答案

您使用的帮助器有误或使用了错误的帮助器。

在第一种情况下,更改模板以使用 {{#if}} 助手:

{{#if (isObject this)}}
<span>Object</span>
{{else}}
<span>String</span>
{{/if}}

看看这个fiddle .

第二种情况,你需要在helper中自己实现{{else}}逻辑。
查看 conditionals 的 Handlebars block 助手文档.

关于javascript - 循环内的 Handlebars 助手,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29965750/

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