Удалить модель в коллекции и удалить событие - backbone.js
как удалить удаляемую модель в коллекции и удалить огонь события. Я пробовал people.remove([{ name: "joe3" }]);
, но он не будет работать.
var Person = Backbone.Model.extend({
initialize: function () {
console.log(" person is initialized");
},
defaults: {
name: "underfined",
age:"underfined"
}
});
var People = Backbone.Collection.extend({
initialize: function () {
console.log("people collection is initialized");
this.bind('add', this.onModelAdded, this);
this.bind('remove', this.onModelRemoved, this);
},
model: Person,
onModelAdded: function(model, collection, options) {
console.log("options = ", options);
alert("added");
},
onModelRemoved: function (model, collection, options) {
console.log("options = ", options);
alert("removed");
},
});
//var person = new Person({ name: "joe1" });
var people = new People();
//people.add([{ name: "joe2" }]);
people.add([{ name: "joe1" }]);
people.add([{ name: "joe2" }]);
people.add([{ name: "joe3" }]);
people.add([{ name: "joe4" }]);
people.add([{ name: "joe5" }]);
people.remove([{ name: "joe3" }]);
console.log(people.toJSON());
Ответы
Ответ 1
Выполняя:
people.remove([{ name: "joe3" }]);
вы не удаляете модель, потому что вы передаете простой объект, который не связан с коллекцией people
. Вместо этого вы можете сделать что-то вроде этого:
people.remove(people.at(2));
Или:
var model = new Person({name: "joe3"});
people.add(model);
...
people.remove(model);
также будет работать.
Итак, вам нужно ссылаться на фактический объект модели из коллекции;
http://jsfiddle.net/kD9Xu/
Ответ 2
Для всех, кто ищет удаление, вы можете просто связать его с вызовом collection.where. например, чтобы удалить все элементы, соответствующие запросу:
people.remove(people.where({name: "joe3"}));
см. Backbone collection.where
Ответ 3
var Person = Backbone.Model.extend({
defaults: {
name: "underfined",
age:"underfined"
}
});
var People = Backbone.Collection.extend({
initialize: function () {
this.bind('remove', this.onModelRemoved, this);
},
model: Person,
onModelRemoved: function (model, collection, options) {
alert("removed");
},
getByName: function(name){
return this.filter(function(val) {
return val.get("name") === name;
})
}
});
var people = new People();
people.add(new Person({name:"joe1"}));
people.add(new Person({name:"joe2"}));
people.remove(people.getByName("joe1"));
console.info(people.toJSON());
Ответ 4
Другой способ немного короче и запускает событие удаления для коллекции:
people.at(2).destroy();
// OR
people.where({name: "joe2"})[0].destroy();
Запускает событие "уничтожить" на модели, которое будет пузыриться через любые коллекции, содержащие его. http://backbonejs.org/#Model-destroy
Ответ 5
Чтобы удалить "[0]", вы можете использовать следующий код:
people.findWhere({name: "joe2"}).destroy();