数组 – 可以通过在另一个数组中的包含来过滤angular.js吗?

前端之家收集整理的这篇文章主要介绍了数组 – 可以通过在另一个数组中的包含来过滤angular.js吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
所以如果我有一个数组:
$scope.letters = 
[{"id":"a"},{"id":"b"},{"id":"c"}];

和另一个数组

$scope.filterBy = ["b","c","d"];

而且我想要一些ng重复过滤$ scope.letters只有$ filterBy中出现的项目。

我想能够做一些事情:

<span ng-repeat="{{letter in letters|filter: letter.id in filterBy }} > {{letter.id}} </span>

并打印b,c

我知道这是一个非常愚蠢的例子,但是有没有办法基于另一个数组对象的内容过滤一个angular.js表达式?

你应该尝试这样的事情:

JS:

angular.module('Test',[]);

function Ctrl($scope) {
  $scope.letters = [
    {id: 'a'},{id: 'b'},{id: 'c'}
  ];

  $scope.filterBy = ['b','c','d'];

  $scope.filteredLetters = function () {
    return $scope.letters.filter(function (letter) {
      return $scope.filterBy.indexOf(letter.id) !== -1;
    });
  };
}

Ctrl.$inject = ['$scope'];

HTML:

<div ng-repeat='letter in filteredLetters(letters)'>{{letter.id}}</div>

你可以试试live example

猜你在找的Angularjs相关文章