AngularJS : Custom filters and ng-repeat

前端 未结 4 1948

I\'m an AngularJS newbie and I\'m building up a small proof-of-concept car hire listings app that pulls in some JSON and renders out various bits of that data via an ng-repe

相关标签:
4条回答
  • 2020-11-27 11:36

    If you want to run some custom filter logic you can create a function which takes the array element as an argument and returns true or false based on whether it should be in the search results. Then pass it to the filter instruction just like you do with the search object, for example:

    JS:

    $scope.filterFn = function(car)
    {
        // Do some tests
    
        if(car.carDetails.doors > 2)
        {
            return true; // this will be listed in the results
        }
    
        return false; // otherwise it won't be within the results
    };
    

    HTML:

    ...
    <article data-ng-repeat="result in results | filter:search | filter:filterFn" class="result">
    ...
    

    As you can see you can chain many filters together, so adding your custom filter function doesn't force you to remove the previous filter using the search object (they will work together seamlessly).

    0 讨论(0)
  • 2020-11-27 11:42

    One of the easiest ways to fix this is to use the $ which is the search all.

    Here is a plunker that shows it working. I have changed the checkboxes to radio ( because I thought they should be complementary )..

    http://plnkr.co/edit/dHzvm6hR5P8G4wPuTxoi?p=preview

    If you want a very specific way of doing this ( instead of doing a generic search ) you need work with functions in the search.

    The documentation is here

    http://docs.angularjs.org/api/ng.filter:filter

    0 讨论(0)
  • 2020-11-27 11:46

    If you still want a custom filter you can pass in the search model to the filter:

    <article data-ng-repeat="result in results | cartypefilter:search" class="result">
    

    Where definition for the cartypefilter can look like this:

    app.filter('cartypefilter', function() {
      return function(items, search) {
        if (!search) {
          return items;
        }
    
        var carType = search.carType;
        if (!carType || '' === carType) {
          return items;
        }
    
        return items.filter(function(element, index, array) {
          return element.carType.name === search.carType;
        });
    
      };
    });
    

    http://plnkr.co/edit/kBcUIayO8tQsTTjTA2vO?p=preview

    0 讨论(0)
  • 2020-11-27 11:52

    You can call more of 1 function filters in the same ng-repeat filter

    <article data-ng-repeat="result in results | filter:search() | filter:filterFn()" class="result">
    
    0 讨论(0)
提交回复
热议问题