Для моего приложения AngularJS у меня есть ng-repeat в ng-repeat, например:
HTML:
<div ng-app="myApp">
<div ng-controller="myController">
<h2>working filter</h2>
<div ng-repeat="category in categories">
<h3>{{category}}</h3>
<div ng-repeat="item in items | filter:{price.red: 0} ">{{item.name}}</div>
</div>
<h2>broken filter</h2>
<div ng-repeat="category in categories">
<h3>{{category}}</h3>
<!-- price[category] should be red, blue, yellow, depending on the category in the ng-repeat -->
<!-- price[category] should be bigger then 0 (or not zero, negative values will not occur) -->
<div ng-repeat="item in items | filter:{price[category]: 0} ">{{item.name}}</div>
</div>
</div>
</div>
Javascript:
var myApp = angular.module('myApp', []);
myApp.controller('myController', function ($scope) {
$scope.categories = ['red', 'blue', 'yellow'];
$scope.items = [
{name: 'one', price:{red: 0, blue: 1, yellow: 3} },
{name: 'two', price:{red: 2, blue: 0, yellow: 0}},
]
});
Пожалуйста, посмотрите мой jsFiddle http://jsfiddle.net/hm8qD/
Итак, я столкнулся с двумя проблемами:
- Фильтр не принимает [] скобки, поэтому я не могу сделать фильтр динамическим в зависимости от категории.
- Фильтр должен возвращать товары, у которых цена[категория] больше нуля.
Для большего, чем ноль, я мог бы просто создать собственный фильтр. Однако, насколько мне известно, фильтры не принимают параметры, поэтому у меня нет возможности получить для него категорию (красный, синий или желтый).
Обратите внимание, что это упрощенная версия моего фактического кода, и этот контекст может иметь не лучший смысл. Надеюсь, я ясно объяснил, для чего мне нужен фильтр, так как я новичок в AngularJS.
item in items | filter:filterCriteria
- person TheHippo   schedule 17.05.2013