Как фильтровать свойство объекта в angularJS

Я пытаюсь создать собственный фильтр в AngularJS, который будет фильтровать список объектов по значениям определенного свойства. В этом случае я хочу фильтровать свойство "полярность" (возможные значения "Положительные", "Нейтральные", "Отрицательные" ).

Вот мой рабочий код без фильтра:

HTML:

<div class="total">
    <h2 id="totalTitle"></h2>
    <div>{{tweets.length}}</div>
    <div id="totalPos">{{tweets.length|posFilter}}</div>
    <div id="totalNeut">{{tweets.length|neutFilter}}</div>
    <div id="totalNeg">{{tweets.length|negFilter}}</div>
</div>

Вот массив $scope.tweets в формате JSON:

{{created_at: "Date", text: "tweet text", user:{name: "user name", screen_name: "user       screen name", profile_image_url: "profile pic"}, retweet_count: "retweet count", polarity: "Positive"},
 {created_at: "Date", text: "tweet text", user:{name: "user name", screen_name: "user screen name", profile_image_url: "profile pic"}, retweet_count: "retweet count", polarity: "Positive"},
 {created_at: "Date", text: "tweet text", user:{name: "user name", screen_name: "user screen name", profile_image_url: "profile pic"}, retweet_count: "retweet count", polarity: "Positive"}}

Лучший фильтр, который я мог бы сделать следующим образом:

myAppModule.filter('posFilter', function(){
return function(tweets){
    var polarity;
    var posFilterArray = [];
    angular.forEach(tweets, function(tweet){
        polarity = tweet.polarity;
        console.log(polarity);
        if(polarity==='Positive'){
              posFilterArray.push(tweet);
        }
        //console.log(polarity);
    });
    return posFilterArray;
};
});

Этот метод возвращает пустой массив. И ничего не выводится из инструкции "console.log(полярность)". Похоже, что я не вставляю правильные параметры для доступа к свойству объекта "полярность".

Любые идеи? Ваш ответ очень ценится.

Ответ 1

Вам просто нужно использовать фильтр filter (см. документацию):

<div id="totalPos">{{(tweets | filter:{polarity:'Positive'}).length}}</div>
<div id="totalNeut">{{(tweets | filter:{polarity:'Neutral'}).length}}</div>
<div id="totalNeg">{{(tweets | filter:{polarity:'Negative'}).length}}</div>

Fiddle

Ответ 2

документация содержит полный ответ. В любом случае, так оно и делается:

<input type="text" ng-model="filterValue">
<li ng-repeat="i in data | filter:{age:filterValue}:true"> {{i | json }}</li>

будет фильтровать только age в массиве data, а true - для точного соответствия.

Для глубокой фильтрации

<li ng-repeat="i in data | filter:{$:filterValue}:true"> {{i}}</li>

$ является специальным свойством для глубокого фильтра, а true - для точного соответствия, как указано выше.

Ответ 3

Вы также можете сделать это, чтобы сделать его более динамичным.

<input name="filterByPolarity" data-ng-model="text.polarity"/>

Затем вы будете выглядеть следующим образом:

<div class="tweet" data-ng-repeat="tweet in tweets | filter:text"></div>

Этот фильтр, конечно, будет использоваться только для фильтрации по полярности

Ответ 4

Вы можете попробовать это. его работа для меня 'name' является свойством в обр.

repeat="item in (tagWordOptions | filter:{ name: $select.search } ) track by $index

Ответ 5

У нас есть коллекция, как показано ниже:
введите описание изображения здесь

Синтаксис: {{(Collection/array/list | filter:{Value : (object value)})[0].KeyName}}
Пример: {{(Collectionstatus | filter:{Value:dt.Status})[0].KeyName}}
ИЛИ
Синтаксис: ng-bind="(input | filter)"
Пример: ng-bind="(Collectionstatus | filter:{Value:dt.Status})[0].KeyName"