• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    ThinkPHP整合datatables实现服务端分页的示例代码

    最近做东西有一个需求,因为数据量很大,在这里我决定使用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:;" rel="external nofollow" rel="external nofollow" onclick="show(`查看`,`__URL__/show/id/'+ data + '`,``,`610`)" class="ml-5" style="text-decoration:none">i class="Hui-iconfont">#xe6df;查看/i>/a>';
         html += 'a style="text-decoration:none" class="ml-5" onClick="signDel(this,'+ data +')" href="javascript:;" rel="external nofollow" rel="external nofollow" title="删除">i class="Hui-iconfont">#xe6e2;/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" onfocus="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();
      }

    4) 代码截图:

    a. html页面

     

    b.js部分

     

    以上这篇ThinkPHP整合datatables实现服务端分页的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • Thinkphp3.2.3整合phpqrcode生成带logo的二维码
    • ThinkPHP整合百度Ueditor图文教程
    • Thinkphp整合微信支付功能
    • thinkphp整合微信支付代码分享
    • thinkPHP5框架整合plupload实现图片批量上传功能的方法
    • ThinkPHP 整合Bootstrap Ajax分页样式
    • ThinkPHP上使用多说评论插件的方法
    • ThinkPHP3.2.2的插件控制器功能简述
    • 基于ThinkPHP5.0实现图片上传插件
    • Thinkphp和onethink实现微信支付插件
    • ThinkPHP使用Smarty第三方插件方法小结
    • thinkPHP框架整合tcpdf插件操作示例
    上一篇:PHP实现APP微信支付的实例讲解
    下一篇:PHP实现的多维数组排序算法分析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    ThinkPHP整合datatables实现服务端分页的示例代码 ThinkPHP,整合,datatables,实现,