I’ve become confused about the scoping within an {{#each}} block.
If I have the handlebars script
<script type="text/x-handlebars">
{{#each vars}}
<button {{action foo}}> {{name}} </button>
{{/each}}
</script>
and I set my application controller as
App.ApplicationController = Ember.Controller.extend({
vars: Ember.ArrayController.create({
content: [
{ name: "Cow",
foo: function(){console.log("moo");}
},
{ name: "Cat",
foo: function(){console.log("meow");}
}
]
})
});
The script can see {{name}} just fine and puts it in as the title of the button as you’d expect, but action does not get bound to the foo functions defined within the array members.
Is there are way to do this that I’m missing, or do I need to refactor to make foo be defined directly within ApplicationController?
You can set up an event on
ApplicationControllerand pass in the individual object and call the storedfoo(). Inside of the{{#each vars}}...{{/each}}block you can usethisto pass the actual object to the event handler.JS:
Handlebars:
JSBin example