2

我在 Angular 中有一组对象,我试图以一种非常具体的方式进行排序,但我无法弄清楚。

这是示例 Javascript:

var app = angular.module('app', []);

function Ctrl($scope) {
  $scope.divisions = [      
      {'group':'d','sub':1}, 
      {'group':'a'}, 
      {'group':'z','sub':2},
      {'group':'g','sub':20},
      {'group':'g'},
      {'group':'r','sub':11}];
}

这是示例 HTML:

<div class="test" ng-controller="Ctrl">
  <div ng-repeat="division in divisions | orderBy:['sub','group']">{{division.group}}-{{division.sub}}</div>
<div>

这是小提琴:https ://jsfiddle.net/r4nsyp2v/1/

而不是显示如下:

d-1
z-2
r-11
g-20
a-
g-

我希望它显示如下:

g-20
r-11
z-2
d-1
a-
g-

因此,如果存在,我想从最大到最小显示“子”键,之后是未定义的“子”键。并按组按字母顺序显示具有未定义“子”键的对象。

我还没有找到诀窍....有什么想法吗?

4

1 回答 1

3

您可以像这样创建自定义订单:

$scope.order = function(division) {
  return -(division.sub || 0);
}

在 HTML

<div ng-repeat="division in divisions | orderBy:order">

参见示例https://jsfiddle.net/r4nsyp2v/2/

于 2015-04-01T19:01:59.067 回答