当前位置: 代码迷 >> JavaScript >> 骨干-在初始化集合模型时传递数据
  详细解决方案

骨干-在初始化集合模型时传递数据

热度:39   发布时间:2023-06-13 11:55:01.0

这就是我当前处理传递到集合模型的数据的方式。 但是我不确定这是否是最好/正确的方法。

我的收藏:

define([ 'underscore',  'backbone','models/mymodel'], function(_, Backbone, myModel){
  var MyCollection = Backbone.Collection.extend({
    model: function (attr, options){
        options.data = {data: options.collection.options.some_data};
        return new myModel(attr, options);
    },

    initialize: function(options) {
        this.options = options;
    }

  });

  return MyCollection;
});

我的模型:

define([ 'underscore',  'backbone' ], function(_, Backbone){
  var MyModel = Backbone.Model.extend({
    defaults: {
    },

    initialize: function(attr, options) {
`       console.log(options.data)
    }
  });

  return MyModel;
});

这是初始化集合模型时传递数据的唯一方法吗?

不,在MyCollection中尝试以下方法:

model: myModel,

如果创建新的myModel,请执行以下操作:

var model = new myModel({
     prop1: 'something', // etc
});

您可以覆盖集合如何将属性的哈希值转换为模型。 这是通过完成的,您可以更改传递给此方法的选项:

var MyCollection = Backbone.Collection.extend({
    model:  MyModel,

    _prepareModel: function(attrs, options) {
        options = _.extend({}, options, {
            data: this.options.some_data
        });

        return Backbone.Collection.prototype._prepareModel.call(this, attrs, options);
    },

    initialize: function(models, options) {
        // note that the options hash is the second argument
        this.options = options;
    }
});

还有一个演示

  相关解决方案