灰烬未显示外键字段数据

时间:2018-11-01 10:09:42

标签: javascript ember.js ember-data

我有四个型号

//models/exam.js

name: attr('string'),
owner: belongsTo('user'),


//models/question.js

content: attr('string'),
exam: belongsTo('exam')


//models/answer.js

owner: belongsTo('user'),
question: belongsTo('question'),
answer: attr('string'),
remarks: attr('string'),
exam: belongsTo('exam')


//models/user.js

owner : attr('string'),
email : attr('string'),
password : attr('string'),

我将模型加载到路线中。然后,当我运行以下模板代码时,

{{#each model.answers as |ans|}}
<p>{{ans.question.content}}</p>
{{/each}}

// route.js

import Route from '@ember/routing/route';
import { hash } from 'rsvp';

export default Route.extend({
    model: function(params){
        return hash({
            student: this.store.findRecord('student',params.id),
            answers: this.store.query('answer',{
                owner: params.id
            }),
        });
    }
});

它显示如下输出

<frontend@model:question::ember276:5>
<frontend@model:question::ember281:6>
<frontend@model:question::ember286:4>

为什么显示这样的代码,为什么不显示原始内容?

1 个答案:

答案 0 :(得分:1)

我认为您遇到了一个非常特殊且罕见的案例。内容对于余烬关系具有特殊含义。那是内部的东西,最终用户不应该处理它。但这就是原因,你为什么得到

<frontend@model:question::ember276:5>

{{ans.question.content}} {{!-- .content doesn't return the content attribute --}}

我将通过更改服务器和ember-model的属性名称来解决此问题。如果服务器的属性名称不可变,则将自定义ember-serializer。即:

//app/serializers/person.js (ember g serializer question)
import DS from 'ember-data';

export default DS.JSONAPISerializer.extend({
  attrs: {
    questionContent: 'content' //map server's attribute content to ember-model's questionContent
  }
});