最近做东西有一个需求,因为数据量很大,在这里我决定使用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. redis连接报错:MISCONF Redis is configured to save RDB snapshots, but it is currently not able to...

    连接redis报错: MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persis ...

  2. 京东商品评论的分类预测与LSA、LDA建模

    (一)数据准备 1.爬取京东自营店kindle阅读器的评价数据,对数据进行预处理,使用机器学习算法对评价文本进行舆情分析,预测某用户对本商品的评价是好评还是差评.通过数据分析与模型分析,推测出不同型号 ...

  3. 机器学习实战笔记-5-Logistic回归

    Logistic回归 优缺点 适用范围 优点:计算代价不高,易于理解和实现. 缺点:容易欠拟合,分类精度可能不高. 适用于:数值型和标称型数据. 仅用于二分类 原理: 每个特征都乘以一个回归系数> ...

  4. 机器学习实战笔记-2-kNN近邻算法

    # k-近邻算法(kNN) 本质是(提取样本集中特征最相似数据(最近邻)的k个分类标签). K-近邻算法的优缺点 例 优点:精度高,对异常值不敏感,无数据输入假定: 缺点:计算复杂度高,空间复杂度高: ...

  5. redis 哨兵配置文件解读sentinel.conf

    # Example sentinel.conf # port <sentinel-port>port 8001 # 守护进程模式daemonize yes # 指明日志文件名logfile ...

  6. 2、单线性变量的回归(Linear Regression with One Variable)

    2.1 模型表示 我们通过一个例子来开始:这个例子是预测住房价格的,我们要使用一个数据集,数据集包含俄勒冈州波特兰市的住房价格.在这里,我要根据不同房屋尺寸所售出的价格,画出我的数据集.比方说,如果你 ...

  7. MS DOS 常用命令整理

    最近在开发用到一些dos下的一些指令,还有bat文件,特别是bat的便捷性让我在生活和开发过程中好好使用. dos指令: java com.pdcss.util.JacobService > D ...

  8. 洛谷 P2863 [USACO06JAN]牛的舞会The Cow Prom(Tarjan)

    一道tarjan的模板水题 在这里还是着重解释一下tarjan的代码 #include<iostream> #include<cstdio> #include<algor ...

  9. sd卡无法启动及zc706更改主频后可以进入uboot无法启动kernel的坑

    好长的标题 +_+ 1.sd卡无法启动 起因:kernel底下通过dd测试速度,擦写了sd卡,再启动时发现无法启动 于是重新格式化,再将BOOT.bin 相关dtb u-rootfs zImage和u ...

  10. ivew 【provide/inject] 页面刷新实现reload

    1.App.vue <template> <div id="app"> <router-view v-if="isRouterAlive&q ...