1
我想过滤products
,具体取决于所选的category
,可以通过下拉菜单选择它。 products
通过belongsTo category
控制器中的过滤器值
- 我有什么在控制器改变取决于下拉菜单中选择的值来过滤
products
? - 如何在下拉菜单中添加空白字段并在选择时显示所有产品?
这里是当前灰烬CLI代码:
应用程序/路由/ index.js
import Ember from 'ember';
export default Ember.Route.extend({
model: function() {
return {
categories: this.store.find('category'),
products: this.store.find('product')
};
}
});
应用程序/控制器/ index.js
import Ember from 'ember';
export default Ember.Controller.extend({
selectedCategory: null,
categories: function(){
var model = this.get('model.categories');
return model;
},
products: function(){
var model = this.get('model.products');
return model;
}.property('selectedCategory')
});
app /模板/ index.hbs
<p>
{{view "select"
content=model.categories
optionValuePath="content.id"
optionLabelPath="content.name"
value=selectedCategory
}}
</p>
{{#each product in products}}
<li>{{product.name}}</li>
{{/each}}
应用程序/模型/ product.js
import DS from 'ember-data';
export default DS.Model.extend({
name: DS.attr('string'),
category: DS.belongsTo('category', { async: true }),
});
应用程序/模型/ category.js
import DS from 'ember-data';
export default DS.Model.extend({
name: DS.attr('string'),
products: DS.hasMany('product', { async: true })
});