Ok guys so I have this array of key pair values which I'm using as my model:
var acs = [{'label':'input box'},{'label':'text area'}]; the rest of the code goes as follows
var Action = Backbone.Model.extend({}); var action = new Action(acs); var ActionView = Backbone.View.extend({     tagName:"li",     template: _.template($('#actions-template').html()),     events:{         "click":"makeInput"     },     render:function(){         $(this.el).html(this.template(this.model.toJSON()));         $(".hero-unit>ul").append(this.el);         return this;     },     makeInput:function(){         alert("im in");     } }); var actionView = new ActionView({model:action}); actionView.render(); The question is with regards to the view. How can I loop through the model I'm passing if this is the view I want to have
<script type="text/template" id="actions-template"> <% _.each(action, function(acs) { %>      <a class="btn"><%= label %></a> <% }); %> </script> There is something wrong with my view and the loop I believe. Any clues? Thanks!
Lodash and Underscore are great modern JavaScript utility libraries, and they are widely used by Front-end developers.
Adding Underscore to a Node. Once added, underscore can be referred in any of the Node. js modules using the CommonJS syntax: var _ = require('underscore'); Now we can use the object underscore (_) to operate on objects, arrays and functions.
The _. template() function is an inbuilt function in the Underscore. js library of JavaScript which is used to compile JavaScript templates into functions that can be evaluated for rendering.
Underscore is a JavaScript library that provides a whole mess of useful functional programming helpers without extending any built-in objects.
You'd probably want to do two things:
Adjust the data you supply to the template:
$(this.el).html(this.template({     action: this.model.toJSON() })); 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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With