我有一个带有“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”,它显示了一个带有链接类别的警报。我有“过滤器:?”在哪里我猜过滤器的价值必须来。这是控制器功能:
$scope.filterCategory = (link) ->
alert(link.category)
知道怎么办吗?谢谢!
答案 0 :(得分:47)
您可以在控制器的范围内创建一个用于过滤的对象,并将其传递给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
的密钥自动过滤对象。
有关详细信息,请查看filter docs。
的“参数”部分所以你的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>
答案 1 :(得分:1)
[
{
"seriesName": "Indian Bank",
"dataVlaues": {
"11/12/2017": 50,
"11/13/2017": 40,
"11/14/2017": 60,
"11/11/2017": 100
}
},
{
"seriesName": "Indian Bank1",
"dataVlaues": {
"11/18/2017": 12,
"11/17/2017": 27,
"11/16/2017": 30,
"11/15/2017": 101
}
}
]
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}
];
});