最近做东西有一个需求,因为数据量很大,在这里我决定使用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. 通过VLC的ActiveX进行二次开发,实现一个多媒体播放器 2011-04-10 00:57:23

    http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=25498312&id=218294  通过VLC的ActiveX进行二 ...

  2. linux 查看 python 安装包路径

    [root]# python -c "import fasttext;print(fasttext)"<module 'fasttext' from '/root/anaco ...

  3. deepin修改默认Python2到Python3

    第一步 打开终端 第二步 输入 sudo vi ~/.bashrc 然后你会看到如下界面: 切大写,输入E,进入如下界面,并在最后输入我已经输入的 alias python='python3' ,记住 ...

  4. CentOS下编译Lua使得其支持动态链接

    在Linux下编译Lua时,我一般都是使用的make generic,这样编译没有什么问题,运行lua的程序也都OK,但是,这样在加载外部的C动态 链接库,却总是报下面的错误 dynamic libr ...

  5. Join的7中情况

    一.左外连接 SELECT * FROM A LEFT JOIN B ON A.KEY = B.KEY 二.右外连接 SELECT * FROM A RIGHT JOIN B ON A.KEY = B ...

  6. 学python2.7简单还是python3.0简单,两者区别

    学python2.7简单还是python3.0简单,谈谈两者区别 1. 使用__future__模块 Python 3.X 引入了一些与Python 2 不兼容的关键字和特性.在Python 2中,可 ...

  7. mysql (mariadb)表结构添加修改删除方法总结

    1,添加表字段 alter table table1 add ptel varchar(100) not Null; alter table table1 add id int unsigned no ...

  8. spring(三):spring中BeanPostProcessor的使用

    spring中实现BeanPostProcessor的后置处理器 ApplicationContextAwareProcessor 进入该实现类内部 可以看到:该类帮我们组建IOC容器,判断我们的be ...

  9. JavaScript给动态插入的元素添加事件绑定

    由于实际的需要,有时需要往网页中动态的插入HTML内容,并在插入的节点中绑定事件处理函数.我们知道,用Javascript向HTML文档中 插入内容,有两种方法, 一种是在写HTML代码写入JS,然后 ...

  10. XMPP即时通讯协议使用(二)——基于Smack相关操作

    package com.test; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator ...