Backbone.js 使用 Collection
在前面我们的 Backbone.js 用上了 Model, 但绝大数的情况下我们处理的都是一批的 Model 数据列表,所以需要有一个 Collection 来容纳 Model, 就像 Java 里最常用的 List。
声明 Collection 时需要指定他处理的 Model 类型,也就是个泛型参数,如我们这样定义 Collection:
//define Collection var PeopleCollection = Backbone.Collection.extend({ model: Person //like generic });
然后就是往 Collection 中如何填充 Model 实例,有好多种,这里只演示最直接的方式。还 add, fetch, 及对 Collection 排序, 遍历等各种操作。
//create collection instance var peopleCollection = new PeopleCollection([ { name: 'Mohit Jain', age: 23 }, { name: 'Taroon Tyagi', age: 25, } ]);
在创建 View 实例时把 collection 传递进去
var peopleView = new PeopleView({collection: peopleCollection});
模板中使用的是点操作符来获取属性,所以交给模板显示数据时需调用 Collection 的 toJSON() 转数据,即把字段从 attributes 中提出到外层来。在 View 中需要这样绑定集合数据:
var data = {people: this.collection.toJSON()}; this.$el.html(template(data)); //fill in data
模板中可用 _.each() 函数来遍历:
<% _.each(people, function(person) { %> <li><%= person.name %>, <%= person.age %></li> <% }); %>
这样就能把 Collection 中的数据显示到页面上了,完整例子如下:
<!DOCTYPE html> <html> <head> <script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script> <script src="http://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.5.2/underscore-min.js"></script> <script src="http://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.0.0/backbone-min.js"></script> </head> <body> <ol id="container"></ol> <script type="text/template" id="person_template"> <% _.each(people, function(person) { %> <li><%= person.name %>, <%= person.age %></li> <% }); %> </script> </body> </html> <script> //define Model var Person = Backbone.Model.extend({ defaults : { name : 'unknown', age : 20 } }); //define Collection var PeopleCollection = Backbone.Collection.extend({ model: Person //like generic }); //define View var PeopleView = Backbone.View.extend({ el: '#container', initialize: function(options) { this.render(); }, render: function() { var template = _.template($("#person_template").html()); var data = {people: this.collection.toJSON()}; this.$el.html(template(data)); //fill in data } }); //create collection instance var peopleCollection = new PeopleCollection([ { name: 'Mohit Jain', age: 23 }, { name: 'Taroon Tyagi', age: 25, } ]); //create view and bind model var peopleView = new PeopleView({collection: peopleCollection}); </script>
点击链接 http://fiddle.jshell.net/Unmi/NeNsU/ 运行如上代码,页面输出为:
- Mohit Jain, 23
- Taroon Tyagi, 25
上面用的是 Underscore 的模板,在页面中可以单独的用 <% _.each([0,1,2,3,4], function(i) { %> <p><%= i %></p> <% }); %> 遍历数组 [0,1,2,3,4]。