Search code examples
angularjsangular-filters

Angular filter by array that contains search criteria


Does the built in Angular "filter" support filtering an array in the sense that "filter where array contains "

Such as follows:

$scope.currentFilter = "Allentown";

$scope.users = [{
   name: "user1", 
   locations: [
      { name: "New York", ... },
      { name: "Allentown", ... },
      { name: "Anderson", ... },
   ]

}, ... ];

<div ng-repeat="user in users | filter : { locations: { name: currentFilter } }"></div>

In other words I'm looking to filter to only users with a "locations" array that CONTAINS a location that matches the string by name.

If not, how can I accomplish this with a custom filter?


Solution

  • Your code snippet works as is since Angular 1.2.13. In case you're using an older version (tested on 1.0.1) and don't need to reuse your filtering routine across controllers (in which case you should declare a proper filter), you can pass the built-in filter a predicate function :

    <div ng-repeat="user in users | filter : hasLocation">{{user.name}}</div>
    

    And write something like this :

    $scope.currentFilter = "Allentown";
    
    $scope.hasLocation = function(value, index, array) {
        return value.locations.some(function(location) {
           return location.name == $scope.currentFilter;
        });
    }
    

    Fiddle here.