javascript - 按属性过滤 Emberjs 数据

标签 javascript ember.js

所以我有一个 ember-cli 1.13.8 应用程序,我想在其中查看没有答案的问题。目前,我可以根据属性过滤搜索。例如,我可以搜索问题的“内容”,因为这是对象的一个​​属性。

模型:

回答:

export default DS.Model.extend({
  ...
  content: DS.attr(),
  question: DS.belongsTo('question', { async: true })
});

问题:

export default DS.Model.extend({
  ...
  answers: DS.hasMany('answer', { async: true }),
});

例如,这适用于查询当前模型(问题)的属性:

model(query) {
 return this.store.findAll('question').then(function(questions) {
   return questions.filterBy("content", query);
 });
}

但我无法根据模型属性的属性(在本例中为长度)进行过滤。我想根据那些没有答案的问题进行过滤。

model() {
  return this.store.findAll('question').then(function(questions) {
    return questions.filter(function(item, index, enumberable) {
      return item.answers.length === 0;
    })
  });
}

另一种尝试:

model() {
  this.store.findAll('question').filter('question', function(q) {
    return q.get('answers.length') === 0;
  })
}

我咨询过: Emberjs filter() versus filterProperty()

似乎 filterProperty() 已被弃用,因此示例如下: http://www.kaspertidemann.com/how-to-filter-an-array-of-records-by-a-property-value-in-ember-js/没有帮助。

最佳答案

问题是尚未加载 answers 关系。我的做法是让路由负责获取模型,让 Controller 负责显示数据。

在你想过滤掉没有答案的问题的路由中:

model() {
  return this.store.findAll('question').then( (questions) => {
    let promiseArray = questions.map( (question) => {
      return question.get('answer');
    })

    return Ember.RSVP.all(promiseArray);
  });
}

在 Controller 中过滤模型:

filteredModels: Ember.computed('model.[]', function() {
  return this.get('model').filter( (question) => {
     return question.get('answers.length') === 0;
  })
})

关于javascript - 按属性过滤 Emberjs 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32801236/

相关文章:

javascript - XPath 可以用来搜索 <script> block 吗?

ember.js - 在 Ember.js 模板中,如何打印出 HTML 将使用的模型属性,例如用于图像的 src 或用于链接的 href

javascript - 如何以编程方式在 ember js 中的其他组件/ View 中添加组件或 View

ember.js - Ember 2 - 过渡到通过组件进行路由

javascript - 跨浏览器 Onunload 和 Onbeforeunload ? (尤其是歌剧 11)

javascript - sencha touch 将变量添加到模板/列表/等

ember.js - 模型 Hook 中的 params 为空,但 paramsFor 不为空

javascript - store.CreateRecord 推送记录来存储来自服务器的负面响应

javascript - 是否可以使用 angularJs 将参数从一个状态传递到另一个状态?

用于闭括号的 JavaScript 正则表达式