Datatable не сортируется с датой в формате дд / мм / гггг Angular - PullRequest
0 голосов
/ 08 февраля 2019

Я использую подключаемый модуль с угловыми данными со следующим environemnt:

  • версия узла: v11.1.0
  • угловая версия: 7.2.4
  • угловая-cli версия: 7.3.0
  • версия jquery: 3.3.22
  • версия данных: 1.10.13
  • версия с угловыми данными: ^ 7.0.0

HTML-код:

<div class="col ">
  <table datatable [dtOptions]="dtOptions"  class="table table-striped" style="font-size: 0.8rem;">
    <thead>
    <tr class="text-center">
      <th scope="col">Coupon Code</th>
      <th scope="col">Coupon State</th>
      <th scope="col">Issuance Channel</th>
      <th scope="col">Create Date</th>
      <th scope="col">Expire Date</th>
      <th scope="col">Number Of Redemptions</th>
      <th scope="col">Redemptions</th>
    </tr>
    </thead>
    <tbody>
    <tr class="text-center" *ngFor="let object of allCoupons">
      <td scope="col">{{object.couponCode}}</td>
      <td scope="col">{{object.couponState}}</td>
      <td scope="col">{{object.channel}}</td>

      <td
        scope="col">{{object.createDate | date: 'dd/MM/yyyy' }}</td>

      <td
        scope="col">{{object.expireDate }}</td>

      <td scope="col"> {{object.redemptions.length}}</td>

      <td>
        <div class="btn-group btn-group-sm w-100">
          <button type="button" class="w-100 btn btn-light fas fa-list-alt "
                  title="See Redemptions"
                  (click)="openRedeemModal(content,object.redemptions)">
          </button>
        </div>
      </td>
    </tr>

    </tbody>
  </table>
</div>

И dtOptions:

dtOptions: DataTables.Settings = {};

ngOnInit() {
this.dtOptions = {
  columnDefs: [


    { targets: 3, type: 'date' }

  ]

};
 }

Однако результат не сортируется по дате, как вы можете видеть в демонстрации:

https://angular -datatables-gitter-smpc8z.stackblitz.io

Не могу найти другого способа исправить проблему, и я попробовал все, что нашел в Интернете.

Ответы [ 2 ]

0 голосов
/ 14 февраля 2019

Я наконец смог решить это.Выкладываю это здесь для дальнейшего использования.

Нужно было получить следующий плагин (код не мой)

jQuery.extend( jQuery.fn.dataTableExt.oSort, {
"date-euro-pre": function ( a ) {
var x;

if ( $.trim(a) !== '' ) {
  var frDatea = $.trim(a).split(' ');
  var frTimea = (undefined != frDatea[1]) ? frDatea[1].split(':') : [00, 00, 00];
  var frDatea2 = frDatea[0].split('-');
  x = (frDatea2[2] + frDatea2[1] + frDatea2[0] + frTimea[0] + frTimea[1] + ((undefined != frTimea[2]) ? frTimea[2] : 0)) * 1;
}
else {
  x = Infinity;
}

return x;
},

"date-euro-asc": function ( a, b ) {
return a - b;
  },

 "date-euro-desc": function ( a, b ) {
return b - a;
 }
} );

и создать папку в src/plug-ins/date-euro.js

Затем в представлении (html-файл)) Я просто положил:

  <td scope="col">{{object.createDate | date: 'dd-MM-yyyy'}}</td>

и добавил путь выше под scripts: в angular.json.

И это работает.

0 голосов
/ 08 февраля 2019

Попробуйте поставить дату в формате yyyy/MM/dd.Я думаю, что это может решить проблему с сортировкой, но формат даты будет полностью изменен.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...