我无法过滤 ArrayController 中对象的子记录。
我的模型的结构是这样的:
var Shop = DS.Model.extend({
name: DS.attr('string'),
products: DS.hasMany('product')
});
var Product = DS.Model.extend({
name: DS.attr('string'),
shop: DS.belongsTo('shop')
});
商店有很多产品,产品属于商店。我想基于 Ember.TextField 过滤每个父级的子记录。如果我只使用正则表达式基于他们拥有的属性过滤父记录,则过滤有效。
productSearchResults: function() {
var productSearchTerm = this.get('productSearchTerm');
var regExp = new RegExp(productSearchTerm,'i');
Ember.Logger.log('productSearchTerm', productSearchTerm);
var filteredResults = this.map(function(shop){
var products = shop.get('products');
return products.filter(function(product){
regExp.test(product.get('name'));
});
});
// all items are returned always..
return filteredResults;
}.property('products.@each', 'productSearchTerm')
我尝试在这里使用promises(来源:Filter child-records (hasMany association) with Ember.js),但似乎永远不会访问此productSearchResults属性。我没有从这里得到任何日志输出。在模板中,我循环遍历过滤的产品,那里什么也没有。如果它有任何相关性,我使用的是Ember 1.5.0和Ember Data 1.0.0-beta.7 + canary.b45e23ba。
productSearchResults: function() {
var _that = this;
var productSearchTerm = this.get('productSearchTerm');
var regExp = new RegExp(productSearchTerm,'i');
this.store.find('shop').then(function(shops) {
var promises = shops.map(function (shop) {
return Ember.RSVP.hash({
shop: shop,
products: shop.get('products').then(function (products) {
return products.filter(function (product) {
return regExp.test(product.name);
});
})
});
});
Ember.RSVP.all(promises).then(function (filteredProducts) {
_that.set('filteredProducts', filteredProducts);
});
});
}.property('products.@each', 'productSearchTerm')