0
私はハンドルバーが新しく、回避策を見つけている間、登録されているヘルパーがなぜ機能するのか不思議です。動作しない例は、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ヘルパー(代わりに、コンテキストの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;
});
どれが高く評価され役立ちます。