Порядке убывания по дате фильтр в AngularJS
<div class="recent" ng-repeat="reader in
(filteredItems = (book.reader | orderBy: 'created_at' | limitTo: 1))">
</div>
таким образом, книга поставляется из REST api, и к ней подключено много читателей. Я хочу получить "недавний" читатель.
The created_at
поле имеет значение, которое идентифицирует пользователя как последние. Но приведенный выше код дает мне самый старый читатель. Значит, порядок должен быть перевернут? Есть ли способ иметь сортировку в порядке убывания?
8 ответов:
По данным документация можно использовать
Вы можете префикс аргумент в
orderBy
С' -', чтобы иметь порядок убывания вместо возрастания. Я бы написал это так:<div class="recent" ng-repeat="reader in book.reader | orderBy: '-created_at' | limitTo: 1"> </div>
Это также указано в документации к фильтру orderBy.
возможно, это может быть полезно для кого-то:
в моем случае, я получаю массив объектов, каждый из которых содержит дату, установленную Мангуста.
Я:
ng-repeat="comment in post.comments | orderBy : sortComment : true"
и определил функции:
$scope.sortComment = function(comment) { var date = new Date(comment.created); return date; };
это работает для меня.
и пример кода:
<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/
сортировка по убыванию по дате
это поможет фильтровать записи с датой в порядке убывания.
$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>
в моем случае порядок определяется полем выбора. Я предпочитаю ответ Людвига, потому что вы можете установить направление сортировки в параметрах выбора как таковое:
$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>
см. примеры w3schools: https://www.w3schools.com/angular/angular_filters.asp https://www.w3schools.com/angular/tryit.asp?filename=try_ng_filters_orderby_click
затем добавьте флаг" обратный":
<!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>