加载中...

过滤列表 filter


8.2. 过滤列表 filter

filter 是一个过滤内容的标签。

如果参数是一个字符串,则列表成员中的任意属性值中有这个字符串,即为满足条件(忽略大小写):

  1. <div ng-controller="TestCtrl">
  2. {{ data | filter: 'b' }} <br />
  3. {{ data | filter: '!B' }} <br />
  4. </div>
  5. <script type="text/javascript">
  6. var TestCtrl = function($scope){
  7. $scope.data = [
  8. {name: 'B', age: 4}, {name: 'A', age: 1}, {name: 'D', age: 3}, {name: 'C', age: 3}, ];
  9. }
  10. angular.bootstrap(document.documentElement);
  11. </script>

可以使用对象,来指定属性名, $ 表示任意属性:

  1. {{ data | filter: {name: 'A'} }} <br />
  2. {{ data | filter: {$: '3'} }} <br />
  3. {{ data | filter: {$: '!3'} }} <br />

自定义的过滤函数也支持:

  1. <div ng-controller="TestCtrl">
  2. {{ data | filter: f }} <br />
  3. </div>
  4. <script type="text/javascript">
  5. var TestCtrl = function($scope){
  6. $scope.data = [
  7. {name: 'B', age: 4}, {name: 'A', age: 1}, {name: 'D', age: 3}, {name: 'C', age: 3}, ];
  8. $scope.f = function(e){
  9. return e.age > 2;
  10. }
  11. }
  12. angular.bootstrap(document.documentElement);
  13. </script>

还没有评论.