javascript – 如何设置Handlebars模板的默认参数?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何设置Handlebars模板的默认参数?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1192字,纯文字阅读大概需要2分钟。
内容图文
我编写了一个插入链接的模板助手,非常简单.
Handlebars.registerHelper('link_to', function(href, title) {
return new Handlebars.SafeString('<a href="/' + href + '">' + title + '</a>');
});
它的用法如下:
{{ link_to 'articles' 'Articles' }}
但是,如果href是自描述的,那么在第二个参数中指定大写版本似乎有点多余.因此,如果省略title参数,我想自动设置此行为.类似于以下内容:
Handlebars.registerHelper('link_to', function(href, title) {
if (!title) {
title = href.charAt(0).toUpperCase() + href.slice(1);
}
return new Handlebars.SafeString('<a href="/' + href + '">' + title + '</a>');
});
但是,使用{{link_to’articles’}}进行渲染时,我只得到[object Object].保留第二个参数并不是什么大不了的事,但我只是想知道是否有办法解决这个问题.
解决方法:
Helpers接受一个可选的Hash作为其最终参数.如果模板没有提供散列参数,Handlebars将自动传递一个空对象({}).
[自http://handlebarsjs.com/block_helpers.html起]
因此,当您在helpers参数列表中拥有title时,它将被视为Hash对象.您可以通过在控制台中记录标题来检查.因此,为了使代码工作,您可以使用typeof运算符检查标题类型是否为String.
if(!title || typeof title != 'String') {
title = href.toString().charAt(0).toUpperCase() + href.slice(1);
}
它应该工作.工作范例:
http://jsfiddle.net/prabhat_rai/ve4h39vm/
内容总结
以上是互联网集市为您收集整理的javascript – 如何设置Handlebars模板的默认参数?全部内容,希望文章能够帮你解决javascript – 如何设置Handlebars模板的默认参数?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。