Фильтр по убыванию по дате в AngularJs

<div class="recent" ng-repeat="reader in
    (filteredItems = (book.reader | orderBy: 'created_at' | limitTo: 1))">
</div>

Итак, книга исходит из остального апи, и в нее много читателей. Я хочу получить "последнего" читателя.

Поле created_at имеет значение, которое идентифицирует пользователя как последнее. Но приведенный выше код дает мне самый старый читатель. Итак, порядок должен быть обращен? Есть ли способ сортировки в порядке убывания?

Ответ 1

В соответствии с документацией вы можете использовать аргумент reverse.

filter:orderBy(array, expression[, reverse]);

Измените свой фильтр на:

orderBy: 'created_at':true

Ответ 2

Вы можете префикс аргумента в orderBy с '-', чтобы иметь убывающий порядок вместо восходящего. Я бы написал это следующим образом:

<div class="recent" 
   ng-repeat="reader in book.reader | orderBy: '-created_at' | limitTo: 1">
</div>

Это также указано в документации для фильтра orderBy.

Ответ 3

Возможно, это может быть полезно для кого-то:

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

Я использовал:

ng-repeat="comment in post.comments | orderBy : sortComment : true"

И определил функцию:

$scope.sortComment = function(comment) {
    var date = new Date(comment.created);
    return date;
};

Это сработало для меня.

Ответ 4

И пример кода:

<div ng-app>
    <div ng-controller="FooController">
        <ul ng-repeat="item in items | orderBy:'num':true">
            <li>{{item.num}} :: {{item.desc}}</li>
        </ul>
    </div>
</div>

И JavaScript:

function FooController($scope) {
    $scope.items = [
        {desc: 'a', num: 1},
        {desc: 'b', num: 2},
        {desc: 'c', num: 3},
    ];
}

Вы получите:

3 :: c
2 :: b
1 :: a

В JSFiddle: http://jsfiddle.net/agjqN/

Ответ 5

Descending Сортировать по дате

Это поможет фильтровать записи с датой в порядке убывания.

$scope.logData = [
            { event: 'Payment', created_at: '04/05/17 6:47 PM PST' },
            { event: 'Payment', created_at: '04/06/17 12:47 AM PST' },
            { event: 'Payment', created_at: '04/05/17 1:50 PM PST' }
        ]; 

<div ng-repeat="logs in logData | orderBy: '-created_at'" >
      {{logs.event}}
 </div>

Ответ 6

В моем случае orderBy определяется полем выбора. Я предпочитаю ответ Людвига, потому что вы можете установить направление сортировки в параметрах выбора как таковых:

        $scope.options = [
            { label: 'Title', value: 'title' },
            { label: 'Newest', value: '-publish_date' },
            { label: 'Featured', value: '-featured' }
        ]; 

Разметка:

<select ng-model="orderProp" ng-options="opt as opt.label for opt in options"></select>
<ul>
    <li ng-repeat="item in items | orderBy:orderProp.value"></li>
</ul>

Ответ 7

см. примеры w3schools: https://www.w3schools.com/angular/angular_filters.asp https://www.w3schools.com/angular/tryit.asp?filename=try_ng_filters_orderby_click

затем добавьте флаг "reverse":

<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.4/angular.min.js"></script>
<body>

<p>Click the table headers to change the sorting order:</p>

<div ng-app="myApp" ng-controller="namesCtrl">

<table border="1" width="100%">
<tr>
<th ng-click="orderByMe('name')">Name</th>
<th ng-click="orderByMe('country')">Country</th>
</tr>
<tr ng-repeat="x in names | orderBy:myOrderBy:reverse">
<td>{{x.name}}</td>
<td>{{x.country}}</td>
</tr>
</table>

</div>

<script>
angular.module('myApp', []).controller('namesCtrl', function($scope) {
    $scope.names = [
        {name:'Jani',country:'Norway'},
        {name:'Carl',country:'Sweden'},
        {name:'Margareth',country:'England'},
        {name:'Hege',country:'Norway'},
        {name:'Joe',country:'Denmark'},
        {name:'Gustav',country:'Sweden'},
        {name:'Birgit',country:'Denmark'},
        {name:'Mary',country:'England'},
        {name:'Kai',country:'Norway'}
        ];

    $scope.reverse=false;
    $scope.orderByMe = function(x) {

        if($scope.myOrderBy == x) {
            $scope.reverse=!$scope.reverse;
        }
        $scope.myOrderBy = x;
    }
});
</script>

</body>
</html>