Сортировка AngularJS для текста внутри пользовательских элементов управления и больших чисел

#javascript #jquery #html #angularjs

#javascript #jquery #HTML #angularjs

Вопрос:

Пожалуйста, обратитесь к ссылке ниже

http://codepen.io/anon/pen/fjkcg

HTML:

 <section ng-app="app" ng-controller="MainCtrl">
  <span class="label">Ordered By: {{orderByField}}, Reverse Sort: {{reverseSort}}</span><br><br>
  <table class="table table-bordered">
    <thead>
      <tr>
        <th>
          <a href="#" ng-click="orderByField='firstName'; reverseSort = !reverseSort">
          First Name <span ng-show="orderByField == 'firstName'"><span ng-show="!reverseSort">^</span><span ng-show="reverseSort">v</span></span>
          </a>
        </th>
        <th>
          <a href="#" ng-click="orderByField='lastName'; reverseSort = !reverseSort">
            Last Name <span ng-show="orderByField == 'lastName'"><span ng-show="!reverseSort">^</span><span ng-show="reverseSort">v</span></span>
          </a>
        </th>
        <th>
          <a href="#" ng-click="orderByField='age'; reverseSort = !reverseSort">
          Age <span ng-show="orderByField == 'age'"><span ng-show="!reverseSort">^</span><span ng-show="reverseSort">v</span></span>
          </a>
        </th>
      </tr>
    </thead>
    <tbody>
      <tr ng-repeat="emp in data.employees|orderBy:orderByField:reverseSort">
        <td>{{emp.firstName}}</td>
        <td> <input type="text"
                    ng-init="empx['name_' $index]=emp['lastName']" 
          ng-model="empx['name_' $index]"/> </td>
        <td>{{emp.age}}</td>
      </tr>
    </tbody>
  </table>
</section>
  

Контроллер:

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

app.controller('MainCtrl', function($scope) {
  //$scope.orderByField = 'firstName';
  $scope.reverseSort = false;
  $scope.empx={};
  $scope.data = {
    employees: [{
      firstName: 'John',
      lastName: 'F',
      age: '6703114'
    },{
      firstName: 'Frank',
      lastName: 'D',
      age: '665087589'
    },{
      firstName: 'Sue',
      lastName: 'F',
      age: '5271761234'
    },
               {
      firstName: 'Sue',
      lastName: 'F',
      age: '52'
    },{
      firstName: 'Sue',
      lastName: 'F',
      age: '2334564564564564564'
    }]
  };
});
  

У нас есть элементы управления текстовыми полями и элементы управления датами внутри ng-repeat. когда я выполняю фильтр по фамилии, который не сортируется должным образом. как я могу отсортировать коллекцию, которая находится внутри элементов управления. Сортировка по возрасту и фамилии не работает, сортировка по фамилии не работает, поскольку значение находится внутри элемента управления текстового поля, а возраст не работает из-за большого числа, но оно было обозначено как строка. как я могу добиться правильной работы сортировки во всех случаях.

Комментарии:

1. ваш code pen просто отлично работает! Я не вижу никаких проблем? вы разобрались с этим?

2. @Angular_10 Сортировка по фамилии и возрасту не работает

Ответ №1:

Я думаю, это потому, что ng-init . Вы никогда не должны использовать ng-init, за исключением вложенных ng-повторов.

Попробуйте удалить ng-init и использовать клон (или оригинал) данных ваших сотрудников напрямую —

 empx = data.employees.map(item => angular.extend({}, item));
  

и выполните итерацию по empx, используя ng-model="item.lastName" in template

Комментарии:

1. Я не уверен в вашем решении. как я могу решить эту проблему

2. пожалуйста, укажите скрипку