繁体   English   中英

使用 jQuery DataTables 中的连字符对数据进行排序

[英]Sort data with hyphen in jQuery DataTables

我使用插件来显示数据。 第一列在数字之间有“-”。 当我使用以下代码时

$('#table').DataTable({
   dom:'Brt',
   columnDefs:[{targets:'_all',type:'num-fmt'}]
});

表格显示如下

在此处输入图片说明

我想按以下顺序显示

在此处输入图片说明

无论如何我们可以以相同的格式显示数据但不考虑“-”

您可以根据两个数字的数值为您的数据类型实现自定义搜索插件:

 //source data const srcData = [ {val: '1-1'}, {val: '10-10'}, {val: '100-100'}, {val: '2-2'}, {val: '20-20'}, {val: '3-3'}, {val: '2-1'} ]; //initialize datatables const dataTable = $('table').DataTable({ dom: 't', order: [], data: srcData, columns: [{title: 'Value', data: 'val', type: 'num-num'}] }); //compare function const compare = (a,b) => { ([ax,ay] = a.split('-')); ([bx,by] = b.split('-')); return parseFloat(ax) <= parseFloat(bx) && parseFloat(ay) <= parseFloat(by) ? -1 : 1 } //custom sort plugin for type 'num-num' Object.assign($.fn.DataTable.ext.oSort, { 'num-num-asc': (a,b) => compare(a,b), 'num-num-desc': (a,b) => compare(a,b)*(-1), });
 <!doctype html><html><head><script type="application/javascript" src="https://code.jquery.com/jquery-3.3.1.min.js"></script><script type="application/javascript" src="https://cdn.datatables.net/1.10.19/js/jquery.dataTables.min.js"></script><link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.19/css/jquery.dataTables.min.css"></head><body><table></table></body></html>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM