Backbone fetch返回我的模型的所有实例

Backbone fetch returns all instance of my model

本文关键字:实例 模型 fetch 返回 我的 Backbone      更新时间:2023-09-26

我有以下代码,它应该在我的模型中提取一个对象并用模板渲染它:

 productDetails: function (id) {
        var product = new app.models.Product({id: id});
        product.fetch({
            success: function (data) {
                console.log(data);
                app.slider.slidePage(new app.views.ProductView({model: data}).render().$el);
            }
        });
    }

然而,由于某种原因,data是我所有模型对象的列表:

attributes: Object
0: Object
1: Object
2: Object
3: Object
4: Object
5: Object
6: Object
7: Object
8: Object
9: Object
10: Object
11: Object
12: Object
13: Object
...
id: "73"

我是Backbone的新手,所以我不知道是什么原因导致的。。。

你需要更多的代码吗?

ProductModel.js

app.models.Product = Backbone.Model.extend({
    initialize: function () {
    },
    sync: function (method, model, options) {
        if (method === "read") {
            app.adapters.product.findById(parseInt(this.id)).done(function (data) {
                options.success(data);
            });
        }
    }
});
app.models.ProductCollection = Backbone.Collection.extend({
    model: app.models.Product,
    sync: function (method, model, options) {
        if (method === "read") {
app.adapters.product.findByName(options.data.name).done(function (data) {
                options.success(data);
            });
        }
    }
});

您的adapters.product可能正在引用集合,然后在Product sync函数中返回集合。

解决方案是这样的:

var findById = function (id) {
  var deferred = $.Deferred();
  var product = null;
  var l = products.length;
  for (var i = 0; i < l; i++) {
    if (products[i].id === id) {
      product = products[i];
      break;
    }
  }
  deferred.resolve(product);   // HERE WAS product__s__
  return deferred.promise();
}