我的服务器返回如下的JSON响应:
{
artists: [{
id: "1",
first_name: "Foo",
last_name: "Bar"
}],
studios: [{
id: 1,
name: "Test",
// ...
artist_ids: ["1"]
}]
}
'artist'实际上是一个用户模型,但名称不同。如何将艺术家映射到用户模型?也许是一个糟糕的解释,但如果我将JSON响应服务器重命名为“用户”而不是“艺术家”,并使用下面的模型,一切都像我想要的那样。我只想在服务器端和客户端使用名称“artist”而不是“user”。希望你们明白我的意思。
App.Studio = DS.Model.extend
name: DS.attr 'string'
// ..
users: DS.hasMany 'App.User'
App.User = DS.Model.extend
firstName: DS.attr 'string'
lastName: DS.attr 'string'
studio: DS.belongsTo 'App.Studio'
我想最简单的事情就是艺术家:DS.hasMany'App.User',但显然这不起作用。
答案 0 :(得分:6)
首先,我建议使用最新的Ember / EmberData,因此关系定义如下:
App.Studio = DS.Model.extend({
name: DS.attr('string'),
// ..
users: DS.hasMany('user')
});
App.User = DS.Model.extend({
firstName: DS.attr('string'),
lastName: DS.attr('string'),
studio: DS.belongsTo('studio')
});
接下来,如果您在回复JSON中获得下划线,我建议您使用ActiveModelAdapter
:
App.ApplicationAdapter = DS.ActiveModelAdapter;
最后,在自定义序列化程序中覆盖typeForRoot
和keyForRelationship
应该可以解决您的问题:
App.ApplicationSerializer = DS.ActiveModelSerializer.extend({
typeForRoot: function(root) {
if (root == 'artist' || root == 'artists') { root = 'user'; }
return this._super(root);
},
keyForRelationship: function(key, kind) {
if (key == 'users') { key = 'artists'; }
return this._super(key, kind);
}
});
最后一件事:如果您在keyForRelationship
中命名关系artists
,您甚至可以删除自定义Studio
:
App.Studio = DS.Model.extend({
name: DS.attr('string'),
// ..
artists: DS.hasMany('user')
});
答案 1 :(得分:3)
您是否尝试过创建从用户扩展的Artist模型?
App.Artist = App.User.extend({})
我没有尝试过,但我怀疑这可行。