最近做东西有一个需求,因为数据量很大,在这里我决定使用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. nginx配置多个虚拟主机(mac)

    1 . 安装  通过homebrew安装nginx,默认安装在:/usr/local/Cellar/nginx/版本号.配置文件在路径:/usr/local/etc/nginx ,默认配置文件ngin ...

  2. KEIL建立新唐MCU的工程时,移植官网程序报错变量未定义问题解决方法

    最近在使用新唐的MCU,新唐的MCU使用还算方便,你安装好KEIL之后再安装 Nu-Link_Keil_Driver_V3.00.6909 驱动即可建立新唐的MCU工程,注意的是因为新唐MCU是C51 ...

  3. Vagrant 手册之 box - box 的信息格式

    原文地址 创建 Vagrant 的 box 时,可以提供在运行 vagrant box list -i 时展示的与用户相关的其他信息.例如,可以打包 box,以包含有关该 box 的作者和网站信息: ...

  4. HTML--JS 获取选择框信息

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. DataContract] [DataMember] 程序集引用

    引用,右键->添加引用->System.Runtime.Serialization 添加

  6. 记录XorDDos木马清理步骤

    1.检查 查看定时任务文件发现有两个异常定时任务 [root@manage ~]# cat /etc/crontab # * * * * * user-name command to be execu ...

  7. Aria2+WebUI+caddy搭建私有网盘

    Aria2安装 wget -N --no-check-certificate https://raw.githubusercontent.com/ToyoDAdoubi/doubi/master/ar ...

  8. 《剑指offer》面试题9 斐波那契数列 Java版

    书中方法一:递归,这种方法效率不高,因为可能会有很多重复计算. public long calculate(int n){ if(n<=0){ return 0; } if(n == 1){ r ...

  9. A AFei Loves Magic

    链接:https://ac.nowcoder.com/acm/contest/338/A来源:牛客网 题目描述 AFei is a trainee magician who likes to stud ...

  10. ASP.NET MVC5 +Abp 模板(Startup Templates)

    官网:https://aspnetboilerplate.com/Templates 系统登陆初始账号:admin 密码:123qwe 调试错误: 1.在多语句事务内不允许使用 CREATE DATA ...