如何对ember数据进行多对多反序列化

时间:2014-02-19 03:24:12

标签: javascript rest ember.js ember-data

//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并将帖子从中提取到记录中?

1 个答案:

答案 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和大小写。