Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What's the difference between Handlebars helpers and Ember Handlebars helpers?

I can't catch up with all those changes done to plain Handlebars and modified Ember Handlebars helpers. If I remember correctly you can register a helper with the following methods

  • Ember.Handlebars.helper
  • Ember.Handlebars.registerHelper
  • Ember.Handlebars.registerBoundHelper
  • Handlebars.registerHelper

That's too much for me. Could you explain it down to earth what's the difference?

like image 271
wryrych Avatar asked Aug 01 '13 21:08

wryrych


1 Answers

Ember.Handlebars.registerHelper is a basic helper that does not bind the argument string to a property. For instance, consider a hello helper created with registerHelper that just returns a greeting message.

Ember.Handlebars.registerHelper('hello', function(name) {
  return 'Hello ' + name;
});

When you use it in a template,

{{hello name}}

You will get the display text as, Hello name. The value of the name property is not looked up.

To get the value of the name property into the helper you need, registerBoundHelper. As the name suggests it creates a binding between to the name property. Anytime the name changes the helper is called again to rerender. The implementation is similar,

Ember.Handlebars.registerBoundHelper('hello', function(name) {
  return 'Hello ' + name;
});

The Ember.Handlebars.helper is same as registerBoundHelper with some additional checks to autodetect what kind of helper you want.

The vanilla Handlebars.registerHelper isn't used within Ember. It would create similar helpers for projects not using Ember.

like image 73
Darshan Sawardekar Avatar answered Oct 21 '22 04:10

Darshan Sawardekar