【发布时间】:2011-10-31 17:29:47
【问题描述】:
我有 2 个模型和一个集合。 JobSummary 是模型,JobSummaryList 是 JobSummary 项目的集合,然后我有一个 JobSummarySnapshot 模型,其中包含 JobSummaryList:
JobSummary = Backbone.Model.extend({});
JobSummaryList = Backbone.Collection.extend({
model: JobSummary
});
JobSummarySnapshot = Backbone.Model.extend({
url: '/JobSummaryList',
defaults: {
pageNumber: 1,
summaryList: new JobSummaryList()
}
});
当我在JobSummarySnapshot 对象上调用fetch 时,它会获取所有内容...除非我在summaryList 集合中移动,它们都是object 类型而不是JobSummary。
我认为这是有道理的,因为除了defaults 对象之外,它不知道summaryList 应该是JobSummaryList 类型。我可以遍历每个项目并将其转换为 JobSummary 对象,但我希望有一种方法可以做到这一点,而无需手动进行。
这是我的测试代码(工作 jsfiddle here):
var returnData = {
pageNumber: 3,
summaryList: [
{
id: 5,
name: 'name1'},
{
id: 6,
name: 'name2'}
]
};
var fakeserver = sinon.fakeServer.create();
fakeserver.respondWith('GET', '/JobSummaryList', [200,
{
'Content-Type': 'application/json'},
JSON.stringify(returnData)]);
var callback = sinon.spy();
var summarySnapshot = new JobSummarySnapshot();
summarySnapshot.bind('change', callback);
summarySnapshot.fetch();
fakeserver.respond();
var theReturnedList = callback.getCall(0).args[0].attributes.summaryList;
_.each(theReturnedList, function(item) {
console.log('Original Item: ');
console.log(item instanceof JobSummary); // IS FALSE
var convertedItem = new JobSummary(item);
console.log('converted item: ');
console.log(convertedItem instanceof JobSummary); // IS TRUE
});
更新: 我突然想到我可以覆盖 parse 函数并以这种方式设置它......我现在有这个:
JobSummarySnapshot = Backbone.Model.extend({
url: '/JobSummaryList',
defaults: {
pageNumber: 1,
summaryList: new JobSummaryList()
},
parse: function(response) {
this.set({pageNumber: response.pageNumber});
var summaryList = new JobSummaryList();
summaryList.add(response.summaryList);
this.set({summaryList: summaryList});
}
});
到目前为止,这有效。留下问题以防有人对此发表评论......
【问题讨论】:
标签: javascript ajax json backbone.js