Фильтровать список элементов при нажатии ссылки категории
У меня есть список элементов с "ng-repeat". Каждый элемент содержит div с названием ссылки и ссылкой. При нажатии на категорию я хочу отфильтровать список элементов, чтобы они отображали только элементы этой категории. как я могу это достичь?
До сих пор у меня есть список элементов:
<div class="link_line" ng-repeat="link in links | filter: ? ">
<div class="title"><a href="{{link.url}}" target="_blank">{{link.title}}</a></div>
<div class="category_label" ng-click="filterCategory(link)>{{ link.category }}</div>
</div>
И в контроллере у меня есть функция "filterCategory", которая показывает предупреждение с категорией ссылок. И у меня есть фильтр:? где я предполагаю, что значение фильтра должно получиться. Ths - это функция контроллера:
$scope.filterCategory = (link) ->
alert(link.category)
Любая идея, как действовать? Спасибо!
Ответы
Ответ 1
Вы можете создать объект в области вашего контроллера, предназначенный для фильтрации, и передать его в выражение filter
в ng-repeat
var app = angular.module('app', []);
app.controller('main', function($scope) {
$scope.filters = { };
$scope.links = [
{name: 'Apple', category: 'Fruit'},
{name: 'Pear', category: 'Fruit'},
{name: 'Almond', category: 'Nut'},
{name: 'Mango', category: 'Fruit'},
{name: 'Cashew', category: 'Nut'}
];
});
Итак, теперь у нас есть объект filters
, прикрепленный к области. Если он получает ключ category
, выражение filter
будет автоматически фильтровать объекты в зависимости от того, есть ли у них ключ category
и он соответствует.
Подробнее см. раздел "Параметры" в документах .
Итак, ваш HTML-код может выглядеть так:
<div class="link_line" ng-repeat="link in links | filter:filters">
<div class="title"><a href="{{link.url}}" target="_blank">{{link.title}}</a></div>
<div class="category_label" ng-click="filters.category = link.category">{{ link.category }}</div>
</div>
Вот краткая сценария этого в действии.
Ответ 2
angular.module('app',[])
.controller('MainController', function($scope) {
$scope.team =[
{cat_id:1,team: 'alpha'},
{cat_id:2,team: 'beta'},
{cat_id:3,team: 'gamma'}
];
$scope.players = [
{name: 'Gene',cat_id : 1},
{name: 'George',cat_id : 2},
{name: 'Steve',cat_id : 3},
{name: 'Pzula',cat_id : 2},
{name: 'shrikant',cat_id : 3}
];
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.8/angular.min.js"></script>
<div ng-app="app" ng-controller="MainController">
<ul ng-repeat="(key, value) in team ">
{{value.team}}
<li ng-repeat="p in players " ng-if="p.cat_id==value.cat_id">
{{ p.name }}
</li>
</ul>
</div>