在控制器中链接Angular过滤器,同时使它们可变

时间:2013-07-22 21:57:12

标签: angularjs filter

假设我创建了一个Angular应用并编写了一些新的过滤器:仅显示odd,并仅显示lucky个数字。

有一个oddList过滤器和一个luckyList过滤器:

var app = angular.module('app', []);
app.filter('oddList', function() {
    return function(items) {
        var filtered = [];
        angular.forEach(items, function(item) {
            if (item % 2 !== 0)
                filtered.push(item);
        });
        return filtered;
    };
});
app.filter('luckyList', function() {
    return function(items) {
        var filtered = [];
        angular.forEach(items, function(item) {
            if (item === 2 || item === 7 || item === 11)
                filtered.push(item);
        });
        return filtered;
    };
});

在视图部分,我可以链接这些过滤器:

<ul><li ng-repeat="number in numbers | oddList | luckyList">{$number}</li></ul>

如果有效,我应该看到剩余711

我想为此ng-repeat制作我的过滤器变量我能做的事与此过程类似吗?

假设我将变量过滤器命名为filter:listFilter,以便在我们的控制器中,我们可以动态更新$scope.listFilter

<ul><li ng-repeat="number in numbers | filter:listFilter">{$number}</li></ul>

带伪代码的控制器:

app.controller('main', function($scope, $filter) {
    $scope.numbers = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15];
    $scope.listFilter = $filter('oddList | luckyList');
});

知道如何在控制器中链接(变量)过滤器吗?希望能够在奇怪,幸运和/或两者之间切换。

1 个答案:

答案 0 :(得分:12)

一种方法是使用函数返回过滤后的数据:

function MainCtrl($scope, $filter) {
    $scope.numbers = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15];

    $scope.filteredNumbers = function() {
        var result = $scope.numbers;

        if ($scope.oddListEnabled) {
            result = $filter('oddList')(result);  
        }        
        if ($scope.luckyListEnabled) {    
            result = $filter('luckyList')(result);
        }

        return result;
    };
}

模板:

<ul>
  <li ng-repeat="number in filteredNumbers()">
    {{number}}
  </li>
</ul>

这是一个傻瓜:http://plnkr.co/edit/4ectDA?p=preview