How do I lowercase a field using Handlebars.js?

余生长醉 提交于 2019-12-02 19:57:53
Cyril N.

As simply explained in the doc :

Handlebars.registerHelper('toLowerCase', function(str) {
  return str.toLowerCase();
});

And just use it like this :

<h1>By {{toLowerCase author}}</h1>

If you're just trying to display some text as lowercased in HTML (regardless of whether or not it's generated by handlebars), you can use CSS and apply text-transform like so:

.css-class-here {
    text-transform: lowercase;
}

I created the following helper, but I'm curious if there's a better solution out there.

Handlebars.registerHelper('toLowerCase', function(value) {
    if(object) {
        return new Handlebars.SafeString(value.toLowerCase());
    } else {
        return '';
    }
});

Previous answer from @Eric seems not to work now, my solution is very similar, but probably the definition of helpers changed a little in new versions of handlebars:

Handlebars.registerHelper('tolower', function(options) {
    return options.fn(this).toLowerCase();
});

and in the template

<img src="/media/images/modules/{{#tolower}}{{name}}{{/tolower}}.png"...

Cheers

Doesn't hurt to also check and make sure it is a string and if not return nothing.

Handlebars.registerHelper('lowercase', function (str) {
  if(str && typeof str === "string") {
    return str.toLowerCase();
  }
  return '';
});

Usage :

// now let's pass a string or variable to our helper
{{lowercase 'MY NAME IS'}}

Output :

my name is
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!