ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

javascript – 如何设置Handlebars模板的默认参数?

2019-06-12 07:22:36  阅读:156  来源: 互联网

标签:javascript handlebars-js


我编写了一个插入链接的模板助手,非常简单.

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-js
来源: https://codeday.me/bug/20190612/1224170.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有