loops in underscore js template

折月煮酒 提交于 2019-12-03 04:40:28

You'd probably want to do two things:

  1. Adjust the data you supply to the template:

    $(this.el).html(this.template({
        action: this.model.toJSON()
    }));
    
  2. Adjust the inner part of the template to use acs.label instead of label:

    <a class="btn"><%= acs.label %></a>
    

Demo: http://jsfiddle.net/ambiguous/xczBy/

On second thought, I think you should be working with a collection rather than a single model. You'd want to add this:

var ActionCollection = Backbone.Collection.extend({
    model: Action
});

And then adjust render to use this.collection:

    $(this.el).html(this.template({
        actions: this.collection.toJSON()
    }));

And then start things up like this:

var actions = new ActionCollection(acs);
var actionView = new ActionView({collection: actions});

And finally, refer to actions in the template:

<% _.each(actions, function(acs) { %> 

Demo: http://jsfiddle.net/ambiguous/6VeXk/

This would better match Backbone's key/value based models.

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