jQuery DataTables插件:排序德国日期

jQuery DataTables plugin: Sort German date

本文关键字:日期 排序 DataTables 插件 jQuery      更新时间:2024-03-05

我使用jQuery DataTables插件,我的问题是我的德国日期没有正确排序。它具有以下格式:dd.mm.YYYY HH:iih

我的代码来了:

JSFIDDLE:

https://jsfiddle.net/uxaLn1e3/3/

HTML:

    <table id="my-table">
   <thead>
      <th>Nr. </th>
      <th>Date</th>
      <th>Name</th>
   </thead>
   <tr>
      <td>1</td>
      <td>27.08.2015 19:00h</td>
      <td>Carl</td>
   </tr>
   <tr>
      <td>2</td>
      <td>10.02.2016 14:00h</td>
      <td>Alan</td>
   </tr>
   <tr>
      <td>3</td>
      <td>07.12.2015 21:00h</td>
      <td>Bobby</td>
   </tr>
</table>

JS(已更新,使用ajax):

     $('#my-table').DataTable({
            "ajax": 'my_url',
            "columns": [
                {"data": "nr"},
                {"data": "date"},
                {"data": "name"}
            ],
                "autoWidth": false,
                "order": [],
                "fnCreatedRow": function( nRow, aData, iDataIndex ) {
                   var dateFull = aData.date;
                   var dateFullItems = dateFull.split(' ');
                   var dateDatum = dateFullItems[0];
                   var dateDatumItems = dateDatum.split('.');
                  var dateTime = dateFullItems[1];
                  var dateFormat = dateDatumItems[2] + '-' + dateDatumItems[1] + '-' + dateDatumItems[0] + 'T' + dateTime + ':00Z'; 
                  $(nRow).find('td:nth-of-type(2)').attr('data-sort', dateFormat);
            },
            });

为了排序工作日期,我需要在JS中做哪些调整?

data-sort属性添加到以标准格式存储日期的td(我在这里使用了ISO格式,即YYYY-MM-DDTHH:ii:ssZ):

<tr>
  <td>1</td>
  <td data-sort="2015-08-27T19:00:00Z">27.08.2015 19:00h</td>
  <td>Carl</td>
</tr>
<tr>
  <td>2</td>
  <td data-sort="2016-02-10T14:00:00Z">10.02.2016 14:00h</td>
  <td>Alan</td>
</tr>
<tr>
  <td>3</td>
  <td data-sort="2015-12-07T21:00:00Z">07.12.2015 21:00h</td>
  <td>Bobby</td>
</tr>

现在datatables将考虑这个data-sort值,而不是td的html来对列进行排序。

Live Fiddle

即使是动态创建表,也可以通过两种方式实现:

A。在生成html时添加data-sort属性。

B。在使用jQuery创建数据表后添加data-sort,然后重新命名数据表。

我认为你必须为你的性别数据脚本使用日期时间格式插件,或者对格式化的日期时间进行排序的插件(我建议使用终极日期/时间排序插件)

案例示例:jsfiddle.net/x92amfe4/

您可以通过从字符串中生成JavaScript日期对象来对日期进行排序。然后,您只需要将德语日期("dd.mm.yy")拆分并创建一个新日期:

      new Date(date.split('.')[2], date.split('.')[1]-1, date.split('.')[0])

用于德国日期排序:

dates.sort((a, b) => {
      return new Date(b.split('.')[2], b.split('.')[1]-1, b.split('.')[0]) - new Date(a.split('.')[2], a.split('.')[1]-1, a.split('.')[0]) 
});

注:您可以使用任何日期格式来创建JavaScript日期对象。

new Date(year, month(0-11) [, day [, hour [, minutes [, seconds [, milliseconds]]]]]);