したがって、配列がある場合:
$scope.letters =
[{"id":"a"},
{"id":"b"},
{"id":"c"}];
そして別の配列
$scope.filterBy = ["b","c","d"];
そして、$ filterByに表示されるアイテムのみで$ scope.lettersをフィルタリングするために、ng-repeatが必要です。
私は次のような効果が得られるようになりたいです。
<span ng-repeat="{{letter in letters|filter: letter.id in filterBy }} > {{letter.id}} </span>
そして、b、cを印刷させます
これは本当に愚かな例ですが、別の配列オブジェクトの内容に基づいてangle.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 を試すことができます。
更新
angularモジュール(@InviSの回答に基づく)を使用して、angularアプリケーション: filters-inArrayFilter
@InviSの回答に基づいたangular filtersアプローチ:
フィルターは次のようになります。
.filter('inArray', function($filter){
return function(list, arrayFilter, element){
if(arrayFilter){
return $filter("filter")(list, function(listItem){
return arrayFilter.indexOf(listItem[element]) != -1;
});
}
};
});
ここで、 list はフィルタリングするリストです(このパラメーターはデフォルトで角度によって設定されます)、 arrayFilter はフィルターとして使用している配列であり、 element は、リストでフィルタリングするプロパティの名前です。
このフィルターを使用するには、ng-repeatを次のように使用します。
<div ng-repeat='letter in letters | inArray:filterBy:"id"'>{{letter.id}}</div>
ここで、 inArray はフィルター、 filterBy (このフィルターの最初の引数)は一致する配列であり、 "id" (2番目の引数)は、照合するリストの要素です。配列。
これを試すことができます live example angular filtersアプローチを使用して。
かなり古いですが、私はそれが必要で、少し変更しなければなりませんでした。ここに私のフィルター「notInArray」があります
app.filter('notInArray', function($filter){
return function(list, arrayFilter, element){
if(arrayFilter){
return $filter("filter")(list, function(listItem){
for (var i = 0; i < arrayFilter.length; i++) {
if (arrayFilter[i][element] == listItem[element])
return false;
}
return true;
});
}
};
});
<md-chips ng-model="filter.SelectedValues" md-autocomplete-snap
md-require-match="true">
<md-autocomplete
md-search-text="searchFilterChip"
md-items="val in filter.Values | notInArray:filter.SelectedValues:'Id'"
md-item-text="val.Name"
md-no-cache="true"
md-min-length="0">
<span md-highlight-text="searchFilterChip">{{val.Name}}</span>
</md-autocomplete>
<md-chip-template>
{{$chip.Name}}
</md-chip-template>
</md-chips>
これは改善できると思いますが、私の場合は必要ありません。
それが誰かを助けることを願っています!