//Setup:
Ember: 1.3.2
Handlebars: 1.3.0
jQuery: 2.0.0
-----------------
MongoDB (_id's, embedded data)
我一直在尝试像这样建立自己的多对多关系:
//Model:
App.Post = DS.Model.extend({
title: DS.attr('string'),
content: DS.attr('string'),
links: DS.hasMany('App.Post'),
});
链接应该嵌入为id(希望)显而易见的原因。
经过几天的挖掘,我设法让应用程序通过RESTAdapter正确地序列化并提交数据,我使用的代码如下所示:
//Controller:
App.PostController = Ember.ObjectController.extend({
actions: {
addRelated: function(related) {
var links = this.content.get('links').pushObject(related);
this.content.save();
}
}
});
//Store:
App.Store = DS.Store.extend({
revision: 12,
adapter: DS.RESTAdapter.extend({
url: '/admin/api',
serializer: DS.RESTSerializer.extend({
primaryKey: function(type) {
return '_id';
},
addHasMany: function(hash, record, key, relationship) {
if (/_ids$/.test(key)) {
hash[key] = [];
record.get(this.pluralize(key.replace(/_ids$/, ''))).forEach(function(post) {
hash[key].push(post.get('id'));
});
}
return hash;
}
})
});
});
从我可以收集的内容中,序列化程序期望以
形式提供数据{post: {...}, links: [{...},{...}]}
但是因为链接是post类型,所以如果可能的话我宁愿不创建整个App.Links模型。
我可以将链接映射到帖子吗?如在
{post: {...}, posts: [{...},{...}]}
我尝试添加deserializeHasMany,但在使用App.Post.find()
我猜我需要编写一个自定义提取函数,它接受link_ids并将帖子从中提取到记录中?
答案 0 :(得分:0)
pI没有对此进行测试,但会说:
您应该将模型更改为:
App.Post = DS.Model.extend({
title: DS.attr('string'),
content: DS.attr('string'),
links: DS.hasMany('post'), //changed
});
您的JSON格式应为:
{"posts": [{ "id":3 ... post item .... "links":[3,10]} { "id":4... post item .... "links":[4,11]}]}
除非已加载,否则所有链接都必须包含在JSON中。
我的理解是你不应该重写RESTAdapter和RESTSerializer,因为这应该是开箱即用的 - 如果不是,我首先检查ajax和大小写。