Home >Backend Development >PHP Tutorial >How to use ThinkPHP to integrate datatables to implement server-side paging

How to use ThinkPHP to integrate datatables to implement server-side paging

不言
不言Original
2018-06-09 14:39:101827browse

The following is a sample code for ThinkPHP to integrate datatables to implement server-side paging. It has a good reference value and I hope it will be helpful to everyone.

There is a need to make something recently, because the amount of data is huge. Here I decided to use the server-side paging of datatables, and also need to pass the query conditions to the server. Most of the articles searched on the Internet felt that there were some errors, so I encapsulated them myself. The main configuration/tools are:

Server: php (using thinkphp)

The page style comes from H- ui framework (datatables version is 1.10.0)

The main modified (databases) configuration items are:

1) bProcessing:true using ajax Source

2) serverSide:true Use server-side paging

3) createdRow:function(){} callback function, used to add event or class name

4) aoColumns Used to process and display data, in which the render attribute is used for custom columns

1. The js code of datatables is:

$('.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 &#39;<input type="checkbox" name="select" value="&#39; + data + &#39;" />&#39;;
    },
    "bSortable": false
   },
   { "mData": "id" },
   { "mData": "fromnickname"},
   { "mData": "content" },
   { "mData": "msgtype" },
   { "mData": "time"},
   {
    "sClass": "text-center",
    "data": "id",
    "render": function (data, type, full, meta) {
     html = &#39;<a title="查看" href="javascript:;" rel="external nofollow" rel="external nofollow" onclick="show(`查看`,`__URL__/show/id/&#39;+ data + &#39;`,``,`610`)" class="ml-5" style="text-decoration:none"><i class="Hui-iconfont">查看</i></a>&#39;;
     html += &#39;<a style="text-decoration:none" class="ml-5" onClick="signDel(this,&#39;+ data +&#39;)" href="javascript:;" rel="external nofollow" rel="external nofollow" title="删除"><i class="Hui-iconfont"></i>删除</a>&#39;;
     return html;
    },
    "bSortable": false
   }
  ]
});

2. Server side:

##

控制器:
接收参数如下:
draw    前端传过来的值,原值返回,用于验证
mintime、maxtime 自定义参数(时间)
search.value  datatables搜索框参数,用于查询筛选
order.0.column  要排序的单元格(从0开始,字段需要自己设置)
order.0.dir   排序(升序、降序)
start    起始条数(第几条开始)
length    查询长度
返回的数据如下:
draw    返回前端传过来的值
recordsTotal  记录总条数
recordsFiltered  条件筛选后的记录总条数
data    服务端查询的数据
返回数据形式:json

3. The complete code of the server backend is as follows:

1) Controller code:

public function index()
{
 if(IS_AJAX){
  $list = D(&#39;Msg&#39;)->getData(I(&#39;get.&#39;));
  $this->ajaxReturn($list);
 }
 $this->display();
}

2) Model layer code: (*Among them, the dealTime method is mainly used to process time periods)

public function getData($data)
{
 //获取Datatables发送的参数 必要
 $draw = $data[&#39;draw&#39;]; //这个值直接返回给前台
 //获取时间区间
 $timeArr[&#39;mintime&#39;] = $data[&#39;mintime&#39;];
 $timeArr[&#39;maxtime&#39;] = $data[&#39;maxtime&#39;];
 $where = $this->dealTime($timeArr);
 //搜索框
 $search = trim($data[&#39;search&#39;][&#39;value&#39;]); //获取前台传过来的过滤条件 
 if(strlen($search) > 0) {
  $where[&#39;id|fromnickname|content|msgtype&#39;] = array(&#39;like&#39;,&#39;%&#39;.$search.&#39;%&#39;);
 }
 //定义查询数据总记录数sql
 $recordsTotal = $this->count();
 //定义过滤条件查询过滤后的记录数sql
 $recordsFiltered = $this->where($where)->count();
 //排序条件
 $orderArr = [1=>&#39;id&#39;, 2=>&#39;fromnickname&#39;, 3=>&#39;content&#39;, 4=>&#39;msgtype&#39;, 5=>&#39;time&#39;];
 //获取要排序的字段
 $orderField = (empty($orderArr[$data[&#39;order&#39;][&#39;0&#39;][&#39;column&#39;]])) ? &#39;id&#39; : $orderArr[$data[&#39;order&#39;][&#39;0&#39;][&#39;column&#39;]];
 //需要空格,防止字符串连接在一块
 $order = $orderField.&#39; &#39;.$data[&#39;order&#39;][&#39;0&#39;][&#39;dir&#39;];
 //按条件过滤找出记录
 $result = [];
 //备注:$data[&#39;start&#39;]起始条数 $data[&#39;length&#39;]查询长度
 $result = $this->field(&#39;id,fromnickname,content,msgtype,time&#39;)
     ->where($where)
     ->order($order)
     ->limit(intval($data[&#39;start&#39;]), intval($data[&#39;length&#39;]))
     ->select();
 //处理数据
 if(!empty($result)) {
  foreach ($result as $key => $value) {
   $result[$key][&#39;time&#39;] = date("Y-m-d H:i:s",$value[&#39;time&#39;]);
   $result[$key][&#39;recordsFiltered&#39;] = $recordsFiltered;
  }
 }
 //拼接要返回的数据
 $list = array(
  "draw" => intval($draw),
  "recordsTotal" => intval($recordsTotal),
  "recordsFiltered"=>intval($recordsFiltered),
  "data" => $result,
 );
 return $list;
}

3) Implement custom ajax search

1. 在WdatePicker中添加onpicked回调函数
2. 执行table.fnFilter(),其中table为datatables对象

Take the WdatePicker plug-in as an example (the input box is similar, just bind the onchange event):

<input type="text" onfocus="WdatePicker({maxDate:&#39;#F{ $dp.$D(\&#39;logmax\&#39;)||\&#39;%y-%M-%d\&#39;}&#39;, onpicked:function(){table.fnFilter();}})" name="mintime" id="logmin" class="input-text Wdate" style="width:120px;">

3. The data attribute in the ajax attribute in datatables defines additional parameters to be passed

Example:

ajax: {
  "url":"{:U(&#39;Msg/index&#39;)}",
  "data":function(d){ //额外传递的参数
   d.mintime = $(&#39;#logmin&#39;).val();
   d.maxtime = $(&#39;#logmax&#39;).val();
  }

4) Code screenshot:

a. html page

b.js part

##The above is the entire content of this article. I hope it will be helpful to everyone's study. For more related content, please pay attention to the PHP Chinese website!

Related recommendations:

Analysis of the method of implementing paging function in thinkPHP5


Analysis on the implementation of static caching and dynamic caching in ThinkPHP


The above is the detailed content of How to use ThinkPHP to integrate datatables to implement server-side paging. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn