3
我使用块帮助器#each
创建了一个列表,但我无法在每个循环内部将变量传递给我的部分。handlebars:将变量传递给每个内部的部分
{{#each a-z.letters}}
{{this}} /*[1]*/
<li class="list-inline__item">
{{>button btn="btn-text" addClass='-large' link='letter/{{this}}' label='{{this}}'/*[2]*/}}
</li>
{{/each}}
链接部分:
<a href="{{link}}" class="btn-text {{addClass}}">{{label}}</a>
的输出是:
<ul class="list-inline">
A /*[1]*/
<li class="list-inline__item">
<a href="letter/{{this}}/*[2]*/" class="btn-text -large">{{this}}/*[2]*/</a>
</li>
....
[1]刚用于测试和它的工作原理
[2]如果我想通过它在一个部分里面它不会渲染我的参数
UPDATE
所以这是我的帮手现在扩展我的href与网址。
Handlebars.registerHelper('updateLink', function(options){
var insertAt = "href=";
var content = options.fn(this).trim();
var pos = content.indexOf(insertAt) + insertAt.length+1; // +1 for the quotation marks
content = content.slice(0, pos) + options.hash.url + content.slice(pos, content.length);
return new Handlebars.SafeString(content);
});
链接部分:
{{#updateLink url="letters/"}}
{{>button link=this label=this btn="btn-text" addClass='-large'}}
{{/updateLink}}