无法获得hasMany关联

时间:2013-01-05 09:20:40

标签: ember.js ember-data

我使用了commit eaa1123(ember)和508479d(ember-data)来构建JS文件。

我从我的Rails后端返回了以下JSON,它是使用active_model_serializers(0.6.0)生成的:

{
  "posts": [
    {
      "id": 408,
      "title": "Lorem Ipsum",
      "body": "In at quo tempora provident nemo.",
      "comments": [
        {
          "id": 956,
          "body": "Quo incidunt eum dolorem."
        },
        ...
      ]
    }
  ]
}

以及以下Ember模型:

App.Post = DS.Model.extend({
  title: DS.attr('string'),
  body: DS.attr('string'),
  comments: DS.hasMany('App.Comment', {
    embedded: true
  })
});

App.Comment = DS.Model.extend({
  body: DS.attr('string'),
  post: DS.belongsTo('App.Post')
});

一切看起来都很正常:

post = App.Post.find(408);
post.get('title')
// => "Lorem Ipsum"

但是,我似乎无法接受评论:

comments = post.get('comments')
comments.get('firstObject') instanceof App.Comment
// => true
comments.forEach(function(comment) {
  console.log(comment.get('body'))
})
//=> undefined

当我使用时:

comments.content

我得到一个包含对象的数组,所以:

comments.content[0]
//=> { body: "Quo incidunt eum dolorem.", id: 956 }

但这不是我的预期。

看起来很明显,所以我一定做错了。 作为副作用:目前我无法以简单的方式在模板中呈现我的评论,所以我希望有人可以帮助我解决这个问题。

提前致谢。

1 个答案:

答案 0 :(得分:10)

如果您使用了该提交,则表示您使用的是最新的ember-data修订版,即11。添加 embedded:true 以加载嵌入式关联在版本5或9之间被弃用了一段时间,不太确定。

如果您使用的是默认的restAdapter,则现在需要将嵌入式加载定义为映射,如下所示,而不是关联选项:

App.store = DS.Store.create({
  revision: 11,
  adapter: DS.RESTAdapter.create()
});

App.store.adapter.serializer.map('App.Post', {
   comments: {embedded: 'load'}
});

App.Post = DS.Model.extend({
  title: DS.attr('string'),
  body: DS.attr('string'),
  comments: DS.hasMany('App.Comment')
});

App.Comment = DS.Model.extend({
   body: DS.attr('string'),
   post: DS.belongsTo('App.Post')
});

您可以通过以下链接关注之前的所有讨论:

https://github.com/emberjs/data/issues/504#issuecomment-11256934 https://github.com/emberjs/data/pull/430#issuecomment-10925506

用于加载嵌入式记录的各种修补程序: https://github.com/emberjs/data/pull/541

这不是直接相关的,但是我上面写的所有内容都失败了,然后将此解决方案添加到混合中 使用findAssociation和extractHasMany挂钩进行异步HasMany时,不会实现BelongsTo关联: https://github.com/emberjs/data/issues/525

任何想要快速查看针对“App.store.adapter.serializer.map”调用的内容定义的人的内部信息

当我们调用'App.store.adapter.serializer.map'时,对序列化程序的调用在下面的第536行定义,地图在第二个链接中在线696

https://github.com/emberjs/data/blob/master/packages/ember-data/lib/system/adapter.js#L536 https://github.com/emberjs/data/blob/master/packages/ember-data/lib/system/adapter.js#L696

DS.RESTAdapter 的第67行扩展 DS.Adapter 序列化工具属性指向 DS .RESTSerializer ,其中添加了特定于 RestAdapter 的附加功能。

https://github.com/emberjs/data/blob/master/packages/ember-data/lib/adapters/rest_adapter.js#L67