集合中的骨干重置事件

use*_*992 7 backbone.js

Backbone重置事件如何工作?据我所理解

  1. 从集合中删除所有模型
  2. 添加新的"获取"模型到集合
  3. 触发重置事件

在我的情况下,每个模型在SVG上绘制一些东西,所以我应该在从集合中删除模型之前调用remove函数.从集合中删除模型时会触发哪个事件?

nik*_*shr 9

正如@Paul所指出的那样,在a之前没有触发预定义事件reset.但是,您可以通过覆盖reset集合中的方法来提供自己的方法.例如,

var SVGCollection = Backbone.Collection.extend({
    reset: function(models, options) {
        options = options || {};

        if (!options.silent) {
            this.trigger('prereset', this, options);
        }

        Backbone.Collection.prototype.reset.call(this, models, options);
    }
});
Run Code Online (Sandbox Code Playgroud)

和样本用法

var c = new SVGCollection([
    {id: 1},
    {id: 2}
]);
c.on('prereset', function() {
    console.log(c.pluck('id'));
});
c.on('reset', function() {
    console.log(c.pluck('id'));
});
c.reset({id: 3});
Run Code Online (Sandbox Code Playgroud)

有关演示,请参见http://jsfiddle.net/nikoshr/8vV7Y/

您还可以在每个模型上触发事件.