Angularjs заказать по плаванию

0

JS:

(function(angular) {
  'use strict';
angular.module('orderByExample', [])
  .controller('ExampleController', ['$scope', function($scope) {
    $scope.friends =
        [{name:'John', phone:'2.5-3.3-7.5', age:10},
         {name:'Mary', phone:'10.5-3.7-9.1', age:19},
         {name:'Mike', phone:'10-21-30', age:21},
         {name:'Adam', phone:'11.1-5-10', age:35},
         {name:'Robert', phone:'1-3-7', age:27},
         {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>

Результат:

Число

  • 1-3-7
  • 9-15-20
  • 10-21-30
  • 11.1-5-10
  • 2.5-3.3-7.5
  • 10.5-3.7-9.1

Но я хочу этот результат:

Число

  • 1-3-7
  • 2.5-3.3-7.5
  • 9-15-20
  • 10-21-30
  • 10.5-3.7-9.1
  • 11.1-5-10

Я хочу сортировать только по номеру телефона. http://plnkr.co/edit/JI8bJ54C3ARurK5w1hFU?p=preview

  • 2
    вы должны написать собственный фильтр
Теги:
sorting
angularjs-orderby

1 ответ

1

В вашем примере вы уже сопоставляете номер phoneNumber и сортируете его:

.map(function(friend) {
  // this removes all non-digits
  friend.phoneNumber = Number(friend.phone.replace(/[^\d]/g, ''));
  return friend;
})

Если вы хотите сохранить номер phoneNumber как это просто map() и используйте parseFloat():

.map(function(friend) {
  // this will create a float from the first part until dash of friend.phone
  friend.phoneNumber = parseFloat(friend.phone);
  return friend;
})

Plunkr

Ещё вопросы

Сообщество Overcoder
Наверх
Меню