Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Handlebars: recursive tree structure

I have a tree structure of arbitrary depth that I want to display with Handlebars. I don't see any way to recurse. If I knew the depth, I could hard code it I suppose, but it can be arbitrarily deep.

Something like this, but it needs to recurse at the display children part.

{{#aNode}}
    {{id}
    {{name}}
    {{description}}
    ...spew this same template with each member of {{#children}}...
{{/aNode}}

Handlebars has ways to iterate collections, but no way that I can see to recurse into the children

like image 853
Chris Kessel Avatar asked Oct 03 '13 22:10

Chris Kessel


2 Answers

Found that you can do it with a delegation/embedded file technique. So, it'd look like this:

spew_a_node.mustache (I'm using the Mustache implementation):

{{#aNode}}
    {{id}
    {{name}}
    {{description}}
    {{#children}}
        {{> spew_a_node}}
    {{/children}}    
{{/aNode}}
like image 102
Chris Kessel Avatar answered Sep 23 '22 12:09

Chris Kessel


Here's a nice article and jsfiddle describing exactly how to do it (which is more or less what Chris Kessel has described in his answer):

http://www.boduch.ca/2014/03/recursive-list-building-with-handlebars.html

like image 33
AsGoodAsItGets Avatar answered Sep 24 '22 12:09

AsGoodAsItGets