我尝试使用Ember AppKit和ES6语法创建一个嵌入数据的模型,但我有点困惑。
我发现这篇文章解释了将数据嵌入到模型中的方法: https://github.com/emberjs/data/blob/master/TRANSITION.md#rest-adapter-and-serializer-configuration
但我不知道如何将这个应用到我的范围。我应该添加"地图"进入适配器以指定我的属性将被嵌入,但我不知道如何。
这就是我所拥有的:
适配器/ item.js
export default DS.RESTAdapter.extend({
namespace: 'path/to/api/json'
});
如何在这里添加地图?
模型/ item.js
var attr = DS.attr,
belongsTo = DS.belongsTo;
export default DS.Model.extend({
name: attr('string')
width: belongsTo('valueUnit'),
height: belongsTo('valueUnit'),
weight: belongsTo('valueUnit')
});
我认为这应该是这样的:
export default DS.Model.extend({
name: attr('string')
width: belongsTo('valueUnit', {embedded: 'always'}),
height: belongsTo('valueUnit', {embedded: 'always'}),
weight: belongsTo('valueUnit', {embedded: 'always'})
});
模型/值-unit.js
var attr = DS.attr;
export default DS.Model.extend({
value: attr('number')
unit: attr('string')
});
这就是我从服务器获得的内容:
{
"items": [
{
"id": "123456789",
"width": {
"value": 150,
"unit": "m"
},
"height": {
"value": 5.3,
"unit": "ft"
},
"weight": {
"value": 12,
"unit": "lb"
}
}
]
}
由于
答案 0 :(得分:0)