使用 this.store.filter 和 belongs_to 模型的 ID

Using this.store.filter with the ID of the belongs_to model

我正在尝试检索给定帐户的所有布局。

/app/models/account.js

import DS from 'ember-data';

export default DS.Model.extend({
  companyName: DS.attr('string'),
  layouts: DS.hasMany('layout')
});

/app/models/layout.js

import DS from 'ember-data';

export default DS.Model.extend({
  name: DS.attr('string'),
  account: DS.belongsTo('account', { async: true })
});

/app/routes/layouts.js

import Ember from 'ember';

export default Ember.Route.extend({
  model: function() {
    return Ember.RSVP.hash({
      layouts: this.store.filter('layout', { account_id: 1 }, function(layout) {
        console.log(layout.get('account').content.id);
        return layout.get('account').content.id === 1;
      })
    });
  }
});

console.log 行正在输出我期望的 ID (1)。在 Ember inspector 中,我可以看到 5 个布局模型,在 'Belongs To' 下,我可以看到:account : <DS.PromiseObject:ember960>。单击会显示 content : <batmics@model:account::ember600:1>,然后单击会显示属性,包括正确的 ID。

但在我的模板中 layouts 是空的...我不知道为什么。

顺便说一句,layouts: this.store.find('layout', { account_id: 1 }) 有效,但我需要它来使用过滤器,以便它成为一个活动数组。

Ember 数据使用其所有 ID 作为字符串。

将支票更改为 === '1' 应该可以解决这个问题。

import Ember from 'ember';

export default Ember.Route.extend({
  model: function() {
    return Ember.RSVP.hash({
      layouts: this.store.filter('layout', { account_id: 1 }, function(layout) {
        console.log(layout.get('account').content.id);
        return layout.get('account').content.id === '1';
      })
    });
  }
});