我是 Handlebars 的新手,虽然我找到了一种解决方法,但我想知道为什么一个注册的助手可以工作而一个不能。不起作用的示例是来自 HB 文档的示例。
HTML:
<ul class="global-nav clearfix">
{{#each data}}
<li><a href="{{href}}">{{text}}</a></li>
{{/each}}
</ul>
...
<ul class="content-nav clearfix">
{{#each data}}
<li><a href="{{href}}">{{text}}</a></li>
{{/each}}
</ul>
数据:
var nav = [
{
name: 'global',
selector: $('.global-nav'),
data: [
{
text: 'Page 1',
href: 'page1.html'
}, {
text: 'Page 2',
href: 'page2.html'
}
],
name: 'content',
selector: $('.content-nav'),
data: [
{
text: 'Section 1',
href: '#section1'
}, {
text: 'Section 2',
href: '#section2'
}
]
}
];
编译器:
$.each(nav, function() {
var obj = this,
src = obj.selector.html(),
template = Handlebars.compile(src),
html = template(obj.data);
obj.selector.html(html);
});
HB 助手(不起作用 - 上下文未定义):
Handlebars.registerHelper('each', function(context, options) {
var ret = "";
for(var i=0, j=context.length; i<j; i++) {
ret = ret + options.fn(context[i]);
}
return ret;
});
HB Helper(使用this
而不是上下文工作):
Handlebars.registerHelper('each', function(context, options) {
var ret = "";
for(var i=0, j=this.length; i<j; i++) {
ret = ret + options.fn(this[i]);
}
return ret;
});
任何帮助表示赞赏。