AngularJS orderyby 两位数

AngularJS orderyby on two digits

JS:

(function(angular) {
  'use strict';
angular.module('orderByExample', [])
  .controller('ExampleController', ['$scope', function($scope) {
    $scope.friends =
        [{name:'John', phone:'2-3-7', age:10},
         {name:'Mary', phone:'2-3-9', age:19},
         {name:'Mike', phone:'10-21-30', age:21},
         {name:'Adam', phone:'1-5-9', age:35},
         {name:'Julie', phone:'9-15-20', age:29}];
    $scope.predicate = 'phone';
    $scope.reverse = true;
    $scope.order = function(predicate) {
      $scope.reverse = ($scope.predicate === predicate) ? !$scope.reverse : false;
      $scope.predicate = predicate;
    };
  }]);
})(window.angular);

HTML:

<table class="friend">
    <tr>        
     <th>
         <button ng-click="order('phone')">Phone Number</button>
         <span class="sortorder" ng-show="predicate === 'phone'" ng-class="{reverse:reverse}"></span>
     </th>         
    </tr>
    <tr ng-repeat="friend in friends | orderBy:predicate">
      <td>{{friend.name}}</td>
      <td>{{friend.phone}}</td>
      <td>{{friend.age}}</td>
    </tr>
  </table>

结果:

人数

但我想要这个结果:

人数

我只想根据数量排序

这是 plunker link: http://plnkr.co/edit/QPNVtKQCqk2nYYkFx4aX?p=preview

您可以按 phone 的数字表示排序。例如像这样:

$scope.friends = [...].map(function(friend) {
    friend.phoneNumber = Number(friend.phone.replace(/[^\d]/g, ''));
    return friend;
});

然后在模板中使用 phoneNumber 进行排序:

<th>
     <button ng-click="order('phoneNumber')">Phone Number</button>
     <span class="sortorder" ng-show="predicate === 'phoneNumber'" ng-class="{reverse:reverse}"></span>
</th>

演示: http://plnkr.co/edit/CgYc5wRBmJLMWDfG74gI?p=info