我在使用Ember 2.0加載關係數據時遇到了一些問題。鑑於以下兩個型號,項目和LineItem的,我想列出一個給定的項目中的所有行項目:使用Ember 2加載關係數據
export default DS.Model.extend({
name: DS.attr(),
organisation: DS.attr(),
customer: DS.attr(),
hours: DS.attr({defaultValue: 0}),
line_items: DS.hasMany('line-item', {async: true})
});
export default DS.Model.extend({
name: DS.attr(),
value: DS.attr({defaultValue: 1}),
quantity: DS.attr({defaultValue: 1}),
state: DS.attr({defaultValue: 'OPEN'}),
project: DS.belongsTo('project')
});
我的路線裏面,我打開一個特定的項目沒有問題:
export default Ember.Route.extend(AuthenticatedRouteMixin, {
model(params) {
return this.store.findRecord('project', params.project_id);
}
});
在我的組件內部,我嘗試加載我的訂單項,如下所示:
import'Ember from'ember';
export default Ember.Component.extend({
store: Ember.inject.service(),
lineItems: function() {
return this.get('project').get('line_items').toArray();
}.property('project.line_items'),
});
當我嘗試但我行項目迭代我的模板內,沒有任何反應:
{{#each lineItems as |item|}}
<tr>
<td>
<a href="#">{{item.name}}</a>
</td>
</tr>
{{/each}}
沒有運氣使用{{#each project.line_items as |item|}}
無論是。打印this.get('project').get('line_items').toArray()
的輸出顯示一個空列表。
但是我的項目中包含行項目,符合市場預期:
{
"data":{
"type":"projects",
"id":"7d93633d-a264-4cb3-918c-82cc44cb76e2",
"attributes":{
"created":"2016-04-04T19:02:03.113408Z",
"modified":"2016-04-04T19:02:03.113511Z",
"name":"Sample name",
"hours":0
},
"relationships":{
"line_items":{
"meta":{
"count":1
},
"data":[
{
"type":"LineItem",
"id":"01915d73-fde5-4b6f-8915-174c16592942"
}
]
}
}
}
}
...我行項目:
{
"type": "line-items",
"id": "01915d73-fde5-4b6f-8915-174c16592942",
"attributes": {
"created": "2016-04-04T19:02:15.622483Z",
"modified": "2016-04-04T19:02:15.622534Z",
"name": "Test Line Item",
"value": 1,
"quantity": 1
},
"relationships": {
"project": {
"data": {
"type": "projects",
"id": "7d93633d-a264-4cb3-918c-82cc44cb76e2"
}
}
}
}
我測試了你的代碼,是的,它不工作。它只有在我將模型「item」和「items」重新命名的情況下才有效。它看起來對我來說,Ember Data不喜歡串接的型號名稱...... – Zoltan
謝謝Zoltan!你的意思是代替模型名稱'line-item'它應該被稱爲'items'? – JB2
這就是它佐爾坦。謝謝 - 這解決了它! – JB2