DataTable自定义排序

使用JQ DataTable 的时候,希望某列数据可以进行自定义排序,操作如下:(以中文排序和百分比排序为例)

1:定义排序类型:

 
  1. //百分率排序  
  2. jQuery.fn.dataTableExt.oSort['number-fate-asc']  = function(s1,s2) {  
  3.     s1 = s1.replace('%','');  
  4.     s2 = s2.replace('%','');  
  5.     return s1-s2;  
  6. };  
  7.   
  8. jQuery.fn.dataTableExt.oSort['number-fate-desc'] = function(s1,s2) {  
  9.     s1 = s1.replace('%','');  
  10.     s2 = s2.replace('%','');  
  11.     return s2-s1;  
  12. };  
  13. //中文排序  
  14. jQuery.fn.dataTableExt.oSort['chinese-string-asc']  = function(s1,s2) {  
  15.     return s1.localeCompare(s2);  
  16. };  
  17. jQuery.fn.dataTableExt.oSort['chinese-string-desc'] = function(s1,s2) {  
  18.     return s2.localeCompare(s1);  
  19. };   



 

2:指定排序的列:

 
    1. $('#flexme1').dataTable({  
    2.     "aoColumns": [  
    3.         null,  
    4.         { data: 'area', "sType": "chinese-string" },//中文排序列  
    5.         null,  
    6.         { data: 'percent', "sType": "number-fate" },//百分率排序  
    7.         null,  
    8.         null  
    9.     ]  
    10. });
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
jQuery DataTables是一个非常流行的数据表格插件,可以方便地对数据进行排序、分页、搜索等操作。当数据量很大的时候,如果使用客户端分页和搜索,会造成很大的性能问题。这时候,我们可以使用服务器端分页和搜索来解决这个问题。 要实现服务器端分页和搜索,我们需要在服务器端提供一个API接口,接收DataTable发送过来的参数,并根据参数进行相应的查询和排序操作,然后将查询结果返回给DataTable。 以下是一个简单的示例代码: ```javascript $(document).ready(function() { $('#example').DataTable( { "processing": true, "serverSide": true, "ajax": { "url": "/api/data", "type": "POST", "data": function ( d ) { d.custom_param1 = "custom_value1"; // 添加其他参数 } }, "columns": [ { "data": "id" }, { "data": "name" }, { "data": "age" }, { "data": "gender" }, { "data": "email" } ] } ); } ); ``` 在这个示例中,我们使用了服务器端分页和搜索功能,设置了`processing`和`serverSide`两个参数为`true`。然后在`ajax`中设置了发送到服务器的参数,可以添加一些自定义的参数。`url`参数指定了API接口的地址,`type`参数指定了发送请求的方法类型。`columns`参数用于设置表格的列。 在服务器端,我们需要解析DataTable发送过来的参数,然后根据参数进行相应的查询和排序操作。以下是一个简单的示例代码: ```php <?php // 解析 DataTable 发送过来的参数 $start = $_POST['start']; $length = $_POST['length']; $search = $_POST['search']['value']; $sort_column = $_POST['order'][0]['column']; $sort_dir = $_POST['order'][0]['dir']; // 构建查询语句 $sql = "SELECT * FROM mytable WHERE 1=1"; if (!empty($search)) { $sql .= " AND (name LIKE '%$search%' OR email LIKE '%$search%')"; } if (!empty($sort_column)) { $columns = array('id', 'name', 'age', 'gender', 'email'); $sql .= " ORDER BY " . $columns[$sort_column] . " $sort_dir"; } $sql .= " LIMIT $start, $length"; // 执行查询操作,并将查询结果返回给 DataTable $result = mysqli_query($conn, $sql); $data = array(); while ($row = mysqli_fetch_assoc($result)) { $data[] = $row; } $response = array( "draw" => intval($_POST['draw']), "recordsTotal" => $total_records, "recordsFiltered" => $filtered_records, "data" => $data ); echo json_encode($response); ``` 在这个示例中,我们首先解析DataTable发送过来的参数,然后根据参数构建查询语句。查询语句中包含了分页、搜索、排序等操作。最后将查询结果返回给DataTable。注意,返回的数据必须是JSON格式。 以上就是一个简单的服务器端分页和搜索示例。实际应用中,我们需要根据具体的业务需求进行相应的修改和优化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值