在技术的世界里,我只能屏住呼吸。
分类: JavaScript
2014-04-28 14:44:48
原文地址:Backbone.js的集合详解(上) 作者:jieforest
Backbone.js的集合只是一个简单的有序集的模型。通过适应模型和集合,我们可以避免数据处理逻辑放到了我们的视图层。此外,模型和集合还提供了便利的与后端一起工作的方法,当数据发生变化时,可以自动化地标记Backbone.js视图。这样,它可以用于如下的情况:
Model: Animal, Collection: Zoo
Model: person, Collection: Office Model: person, Collection: Home
var Music = Backbone.Model.extend({ initialize: function(){ console.log("Welcome to the music world"); } }); var Album = Backbone.Collection.extend({ model: Music });
var Music = Backbone.Model.extend({ defaults: { name: "Not specified", artist: "Not specified" }, initialize: function(){ console.log("Welcome to the music world "); } }); var Album = Backbone.Collection.extend({ model: Music }); var music1 = new Music ({ id: 1 ,name: "How Bizarre", artist: "OMC" }); var music 2 = new Music ({id: 2, name: "What Hurts the Most", artist: “Rascal Flatts" }); var myAlbum = new Album([music 1, music 2]); console.log( myAlbum.models );
一、添加模型到集合
正如我们所知的那样,集合是模型的集合。因此,我们可以在集合上添加模型。要添加模型到集合,我们可以使用add方法。我们还可以添加模型到集合的开始——通过使用unshift方法。
var music3 = new Music({ id: 3, name: "Yes I Do",artist:“Rascal Flatts" }); Music.add(music3); console.log('New Song Added'); console.log(JSON.stringify(Music));
二、从集合中移除模型
很多时候,我们会有从集合中移除一些指定的数据这样的需求。要从集合中移除模型,我们需要提供模型的id。如果我们想用一个完整的新数据集替换原集合,我们可以使用reset方法。
Music.remove(1); console.log('How Bizarre removed...'); console.log(JSON.stringify(Music));
三、Get和Set
如果我们需要从代码其它地方的集合中获取一个值,那么可以直接使用get方法。此时,我们向带检索的模型传递ID值。
console.log(JSON.stringify(Music.get(2)));
var Music = Backbone.Model.extend({ // This attribute should be set as a default defaults: { Name: '' }, // Set the id attribute so that the collection idAttribute: 'id' }); var song = Backbone.Collection.extend({ model: Music }); var models = [{ Name: 'OMC', id: 1 }, { Name: 'Flatts', id: 2 }]; var collection = new song(models); collection.bind('add', function (model) { alert('addb') }); collection.bind('remove', function () { alert('add') }); models = [{ Name: 'OMC', id :1 }, { Name: 'Flatts', id: 2 }, { Name: ' Jackson ', id: 3 }]; collection.add(models); });