最近做东西有一个需求,因为数据量很大,在这里我决定使用datatables的服务端分页,同时还需要传递查询条件到服务端。在网上搜索的大部分文章都感觉有些误差,于是自己封装了一下,主要配置/工具为:

服务端:php(使用thinkphp) 
页面样式来自于H-ui框架(datatables版本为1.10.0)

主要修改(databases)配置项为: 
  1) bProcessing:true 使用ajax源 
  2) serverSide:true 使用服务端分页 
  3) createdRow:function(){} 回调函数,用于添加事件或类名 
  4) aoColumns 用于处理、显示数据,其中render属性用于自定义列

1.datatables 的js代码为:

$('.table-sort').dataTable({
   processing: true,
       serverSide: true,
       ajax: {
           "url":"{:U('Msg/index')}",
           "data":function(d){    //额外传递的参数
               d.mintime = $('#logmin').val();
               d.maxtime = $('#logmax').val();
           }
       },
       bStateSave: true,//状态保存
       aLengthMenu : [20, 30, 50, 100, 150],
       bProcessing : true,
       bAutoWidth: false,
       bFilter : true, //是否启动过滤、搜索功能
       bInfo : true, //是否显示页脚信息,DataTables插件左下角显示记录数  
       createdRow: function ( row, data, index ) {
           $(row).addClass('text-c');
           $('#count').html(data.recordsFiltered);
       },
       aoColumns: [
           {
               "sClass": "text-center",
                "data": "id",
                "render": function (data, type, full, meta) {
                   return '<input type="checkbox"  name="select"  value="' + data + '" />';
               },
               "bSortable": false
           },
           { "mData": "id" },
           { "mData": "fromnickname"},
           { "mData": "content" },
           { "mData": "msgtype" },
           { "mData": "time"},
           {
               "sClass": "text-center",
                "data": "id",
                "render": function (data, type, full, meta) {
                   html = '<a title="查看" href="javascript:;" οnclick="show(`查看`,`__URL__/show/id/'+ data + '`,``,`610`)" class="ml-5" style="text-decoration:none"><i class="Hui-iconfont">查看</i></a>';
                   html += '<a style="text-decoration:none" class="ml-5" onClick="signDel(this,'+ data +')" href="javascript:;" title="删除"><i class="Hui-iconfont"></i>删除</a>';
                   return html;
               },
               "bSortable": false
           }
       ]
});

2.服务端方面:

控制器:
    接收参数如下:
        draw                前端传过来的值,原值返回,用于验证
        mintime、maxtime    自定义参数(时间)
        search.value        datatables搜索框参数,用于查询筛选
        order.0.column      要排序的单元格(从0开始,字段需要自己设置)
        order.0.dir         排序(升序、降序)
        start               起始条数(第几条开始)
        length              查询长度
    返回的数据如下:
        draw                返回前端传过来的值
        recordsTotal        记录总条数
        recordsFiltered     条件筛选后的记录总条数
        data                服务端查询的数据
        返回数据形式:json

3.服务端后端完整代码如下:

1)控制器代码:

public function index()
{
    if(IS_AJAX){
        $list = D('Msg')->getData(I('get.'));
        $this->ajaxReturn($list);
    }
    $this->display();
}

2) Model层代码:(*其中,dealTime方法主要用于处理时间段)

public function getData($data)
{
   //获取Datatables发送的参数 必要
   $draw = $data['draw'];    //这个值直接返回给前台
   //获取时间区间
   $timeArr['mintime'] = $data['mintime'];
   $timeArr['maxtime'] = $data['maxtime'];
   $where = $this->dealTime($timeArr);
   //搜索框
   $search = trim($data['search']['value']);    //获取前台传过来的过滤条件 
   if(strlen($search) > 0) {
       $where['id|fromnickname|content|msgtype'] = array('like','%'.$search.'%');
   }
   //定义查询数据总记录数sql
   $recordsTotal = $this->count();
   //定义过滤条件查询过滤后的记录数sql
   $recordsFiltered =  $this->where($where)->count();
   //排序条件
   $orderArr = [1=>'id', 2=>'fromnickname', 3=>'content', 4=>'msgtype', 5=>'time'];
   //获取要排序的字段
   $orderField = (empty($orderArr[$data['order']['0']['column']])) ? 'id' : $orderArr[$data['order']['0']['column']];
   //需要空格,防止字符串连接在一块
   $order = $orderField.' '.$data['order']['0']['dir'];
   //按条件过滤找出记录
   $result = [];
   //备注:$data['start']起始条数    $data['length']查询长度
   $result = $this->field('id,fromnickname,content,msgtype,time')
                  ->where($where)
                  ->order($order)
                  ->limit(intval($data['start']), intval($data['length']))
                  ->select();
   //处理数据
   if(!empty($result)) {
       foreach ($result as $key => $value) {
           $result[$key]['time'] = date("Y-m-d H:i:s",$value['time']);
           $result[$key]['recordsFiltered'] = $recordsFiltered;
       }
   }
   //拼接要返回的数据
   $list = array(
       "draw" => intval($draw),
       "recordsTotal" => intval($recordsTotal),
       "recordsFiltered"=>intval($recordsFiltered),
       "data" => $result,
   );
   return $list;
}

3) 实现自定义ajax搜索

1. 在WdatePicker中添加onpicked回调函数

2. 执行table.fnFilter(),其中table为datatables对象

以WdatePicker插件为例(input框类似,绑定onchange事件即可):

<input type="text" οnfοcus="WdatePicker({maxDate:'#F{ $dp.$D(\'logmax\')||\'%y-%M-%d\'}', onpicked:function(){table.fnFilter();}})"  name="mintime" id="logmin" class="input-text Wdate" style="width:120px;">

3. datatables中ajax属性中data属性定义额外要传递的参数
例子:

ajax: {
       "url":"{:U('Msg/index')}",
       "data":function(d){    //额外传递的参数
           d.mintime = $('#logmin').val();
           d.maxtime = $('#logmax').val();
       }

ThinkPHP整合datatables实现服务端分页的更多相关文章

  1. jquery.dataTables的探索之路-服务端分页配置

    最近闲来无事想研究下数据表格,因为之前接触过layui和bootstrap的数据表格,本着能学多少学多少的学习态度,学习下dataTables的服务端分页配置.特与同学们一块分享下从中遇到的问题和解决 ...

  2. 基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询

    前言 基于SpringMVC+Bootstrap+DataTables实现数据表格服务端分页.模糊查询(非DataTables Search),页面异步刷新. 说明:sp:message标签是使用了S ...

  3. asp.net mvc bootstrap datatable 服务端分页

    datatable 服务端分页 因项目需求变动,需处理大量数据,更改成服务端分页,自己两天的学习笔记 先上图[ jqueryui风格] 前端代码: @{ Layout = null;} <!DO ...

  4. asp.net mvc bootstrap datatable 服务端分页 更新槽糕的代码【1】

    datatable 服务端分页 因项目需求变动,需处理大量数据,更改成服务端分页,自己两天的学习笔记 datatable 1.10.7 百度云下载  密码:0ea1 先上图[ jqueryui风格] ...

  5. datatable.js 服务端分页+fixColumns列固定

    前言 记得还是15年的时候,工作需要,独自写后台管理系统..记得那时候,最让我头疼的不是后台逻辑,而是数据的列表展示. 列很多的时候,页面显示问题;分页样式问题;表格样式问题;数据加载...很多细节的 ...

  6. BootStrap-table 客户端分页和服务端分页的区别

    当服务器没有对数据进行分页时,前端页面设计又要求进行分页,要分开来设置. 服务端分页: responseHandler: function(data){ return data.response; } ...

  7. BootStrap Table和Mybatis Plus实现服务端分页

    一.后台java代码(Mybatis Plus分页) (1)Mybatis Plus分页的配置,在mybatis的xml文件中增加如下配置(Mybatis Plus官方文档:http://baomid ...

  8. Angularjs的真分页,服务端分页,后台分页的解决方案

    背景:项目的框架使用的是Angularjs,在做数据展示的时候,使用的是ng-table.用过ng-table的人都知道,他是自带分页的,默认分页方式是假分页.也就是一口气把所有的数据从数据库里取出来 ...

  9. AngularJS中实现服务端分页

    这个教程将介绍在AngularJS应用中的服务端分页处理.在任何涉及到列表或表格数据的应用中都可能会用到分页. 概念 当我们处理异步分页时,每次只从服务器上获取一页数据.也就是说当用户点击第二页,就只 ...

随机推荐

  1. 知道css有个content属性吗?有什么作用?有什么应用?

    css的content属性专门应用在 before/after 伪元素上,用来插入生成内容.最常见的应用是利用伪类清除浮动. //一种常见利用伪类清除浮动的代码 .clearfix:after { c ...

  2. day46----JavaScript的函数及对象小结

    一:函数 01:普通函数 function f1(){ console.log("Helleo world") } f1(); //调用函数 -->Helleo world ...

  3. Failed to load resource: the server responsed with a status of 400 (Bad Request)

    浏览器报错:Failed to load resource: the server responsed with a status of 400 (Bad Request) ajax请求失败,一般情况 ...

  4. 【转载】Spring Boot:常用属性汇总

    附录A.常用应用程序属性 摘自:https://docs.spring.io/spring-boot/docs/current/reference/html/common-application-pr ...

  5. Python笔记(十八)_私有属性、实例属性、类属性

    私有属性 如果要让内部属性不被外部访问,可以把属性的名称前加上两个下划线__,就变成了一个私有属性,只有内部可以访问,外部不能直接访问或修改. 这样就确保了外部代码不能随意修改对象内部的状态,这样通过 ...

  6. android handler 调用原理

    1,调度原理 andriod提供了Handler 和 Looper 来满足线程间的通信.Handler先进先出原则.Looper类用来管理特定线程内对象之间的消息交换(MessageExchange) ...

  7. JS的两种函数声明方式的区别

    ---恢复内容开始--- js中常见的两种函数声明方式如下: // 函数表达式 var f = function() { console.log(1); } // 直接声明 function f () ...

  8. 利用java反射动态调用方法,生成grid数据

    项目中需要java后台查询并组装前台grid的数据,数据行数不定,数据行定义不定,开始用了最原始的方法,写了几百行,就是前台需要什么字段后台拼接什么字段,java代码冗余量非常大,并且不够灵活,一旦前 ...

  9. 在vue中运用mt-loadmore 实现上拉加载,下拉刷新(完整源码)

    <template> <div class="serverList"> <ul class="scrollModeBox" :st ...

  10. 微信小程序(10)--开发者工具更新以后wxss编译错误

    更新最新版微信开发者工具后,出现下面报错: 解决办法: 1.在控制台输入openVendor() ,确定Enter: 2.清除里面的wcc.exe  wcsc.exe : 3.重启开发者工具