最近做东西有一个需求,因为数据量很大,在这里我决定使用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. Gogs 安装 - 本地安装,容器安装

    文章目录 安装 Gogs 本地安装 前提条件: 数据库 git 创建 git 用户 SSH 服务器 安装 升级 配置及运行 配置 运行 Gogs 服务 在线安装 Gogs 后台运行 gogs 通过 d ...

  2. LeetCode 129. Sum Root to Leaf Numbers 动态演示

    树的数值为[0, 9], 每一条从根到叶子的路径都构成一个整数,(根的数字为首位),求所有构成的所有整数的和 深度优先搜索,通过一个参数累加整数 class Solution { public: vo ...

  3. JS动态添加Easyui的HTML时样式丢失

    解决办法: $.parser.parse($("#creatLi").html(<li>xxxxxx</li>)); ------------------- ...

  4. 洛谷P1265 公路修建——prim

    给一手链接 https://www.luogu.com.cn/problem/P1265 这道题本质上就是最小生成树,题目描述就是prim的思想 TIP:注意稠密图和稀疏图的区别 #include&l ...

  5. 洛谷P5018 对称二叉树——hash

    给一手链接 https://www.luogu.com.cn/problem/P5018 这道题其实就是用hash水过去的,我们维护两个hash 一个是先左子树后右子树的h1 一个是先右子树后左子树的 ...

  6. Ubuntu12.04下安装Subversion并进行配置

    Ubuntu下安装Subversion还是很简单的,只要输入sudo apt-get install Subversion就可以安装了. 主要的难点在于对权限的配置上. 安装完subversion后, ...

  7. 67.Task Scheduler(任务规划)

    Level: Medium 题目描述: Given a char array representing tasks CPU need to do. It contains capital letter ...

  8. Go语言_方法和接口

    方法和接口 本节课包含了方法和接口,可以用这种构造来定义对象及其行为. Go 作者组编写,Go-zh 小组翻译. https://tour.go-zh.org/methods/1 方法 Go 没有类. ...

  9. 20191108PHP数组查找练习

    <?php $arr=[20,30,60]; $new=array(22,"tom"=>33); echo $arr[2]; echo $new['tom']; for ...

  10. Dart基础使用手册

    程序入口 在每个app中必须有一个main()函数作为程序的入口点. 你可以在新建的flutter项目中找到它(main.dart) void main() => runApp(MyApp()) ...