AngularJs ng-repeat orderBy 切换

AngularJs ng-repeat orderBy toggle

如何更改 ng-repeat 中的 orderBy 过滤器?默认顺序值是按日期(最近的优先),但是通过单击 toggle_to_sort(),我需要将排序顺序更改为按名称(字母顺序),然​​后如果用户再次单击 - return按日期订购。

angular.module('app', []).controller('ctrl', function($scope) {
  $scope.array = [
    {name: 'item1', date: 1453284120},
    {name: 'item2', date: 1453284440},
    {name: 'item3', date: 1453284550},
    {name: 'item4', date: 1453284086},
    {name: 'item5', date: 1453284330},
  ];
    
  $scope.toggle_to_sort = function() {
    // ??
  }
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.0/angular.min.js"></script>

<div ng-app="app" ng-controller="ctrl">

  <div ng-repeat="item in array  | orderBy:'-date'">
    <div>{{item.name}}</div>
  </div>

  <div ng-click="toggle_to_sort()">Toggle<div>

</div>

声明一个标志

$scope.changeFilter=false;

然后添加这个

<div ng-repeat="item in array  | orderBy: !changeFilter ? '-date' : 'name'">

更改按钮单击时的值

<div ng-click="changeFilter=!changeFilter"><div>

DEMO

在你的 JS 中我会添加这个:

$scope.toggled = false;

然后在您的 HTML 中执行此操作:

<div ng-repeat="item in array  | orderBy:'-date'" ng-hide="toggled">
    <div>{{item.name}}</div>
</div>

<div ng-repeat="item in array  | orderBy:'-name'" ng-show="toggled">
    <div>{{item.name}}</div>
</div>

<div ng-click="toggled=!toggled"><div>

angular.module("myApp",[]).controller("myController",function($scope){
  

  
$scope.array = [
{name: 'item1', date: 1453284120},
{name: 'item2', date: 1453284440},
{name: 'item3', date: 1453284550},
{name: 'item4', date: 1453284086},
{name: 'item5', date: 1453284330},
]
});
<html ng-app="myApp">
  <head>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
    </head>
<body ng-controller="myController">
  <div ng-click="mytoggle=!mytoggle">Name<div><hr>
<div ng-repeat="item in array | orderBy: !mytoggle?'-date':'name' ">
  
 <div>{{item.name}}</div>
</div>
</body>

  </html>

希望对您有所帮助...