2017-07-15 20 views
0

私はAjaxでJquery Datatableを使用してテーブルを作成しました。うまく動作し、データテーブルをフィルタリングするdaterangepickerを作成しました。DatingangepickerパラメータをAjaxでJQuery DataTableに渡す

<link href="./css/font-awesome.min.css" rel="stylesheet" type="text/css" /> 
 
\t <link rel="stylesheet" type="text/css" href="./css/daterangepicker-bs3.css" /> 
 
\t <script type="text/javascript" src="./js/daterangepicker.js"></script> 
 
\t <script type="text/javascript" src="./js/date.js"></script> 
 
\t <script type="text/javascript"> 
 
\t \t $(function() 
 
\t \t { 
 
\t \t \t var startdate = moment().subtract(29, 'days'); 
 
\t \t \t var enddate = moment(); 
 
\t \t \t function cb(startdate, enddate) { 
 
\t \t \t \t $('#reservation span').html(startdate.format('YYYY-MM-DD') + ' ~ ' + enddate.format('YYYY-MM-DD')); 
 
\t \t \t } 
 
\t \t \t $('#reservation').daterangepicker({ 
 
\t \t \t \t start: startdate, 
 
\t \t \t \t end: enddate, 
 
\t \t \t \t ranges: { 
 
\t \t \t \t 'Today': [moment(), moment()], 
 
\t \t \t \t 'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')], 
 
\t \t \t \t 'Last 7 Days': [moment().subtract(6, 'days'), moment()], 
 
\t \t \t \t 'Last 30 Days': [moment().subtract(29, 'days'), moment()], 
 
\t \t \t \t 'This Month': [moment().startOf('month'), moment().endOf('month')], 
 
\t \t \t \t 'Last Month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')] 
 
\t \t \t \t } 
 
\t \t \t }, cb); 
 
\t \t \t cb(startdate, enddate); 
 
\t \t }); 
 
\t </script> 
 
    
 

 
\t <script src="./js/jquery-1.12.4.js" type="text/javascript"></script> 
 
\t <script src="./js/jquery.dataTables.min.js" type="text/javascript"></script> 
 
\t <link rel="stylesheet" href="./css/jquery.dataTables.min.css" type="text/css" /> 
 
\t <script type="text/javascript" charset="utf-8"> 
 
\t \t $(document).ready(function() 
 
\t \t { 
 
\t \t \t // DataTable 
 
    \t \t \t $('#Show-Tables').DataTable({ 
 
\t \t \t \t "processing": true, 
 
\t \t \t \t "serverSide": true, 
 
\t \t \t \t "pagingType": "full_numbers", 
 
\t \t \t \t "ajax": { 
 
\t \t \t \t \t "url": "dt-json-data.php", 
 
\t \t \t \t \t "type": "POST", 
 
\t \t \t \t \t "dataSrc": "records" 
 
\t \t \t \t }, 
 
\t \t \t \t "columns": [ 
 
\t \t \t \t \t { "data": "Tanggal" }, 
 
\t \t \t \t \t { "data": "CustomerNo" }, 
 
\t \t \t \t \t { "data": "CustomerName" }, 
 
\t \t \t \t \t { "data": "Branch" }, 
 
\t \t \t \t \t { "data": "Tot_Menit" }, 
 
\t \t \t \t \t { "data": "Tot_call" } 
 
\t \t \t \t ], 
 
\t \t \t \t "autoWidth": true 
 
\t \t \t }); 
 
\t \t }); 
 
\t </script> 
 

 

 

 
<?php 
 
//Here is my code for dt-json-data.php file : 
 
/* Database connection start */ 
 
$servername = "xxx.xxx.xxx.xxx"; 
 
$username = "xxxx"; 
 
$password = "*******"; 
 
$dbname = "*****"; 
 

 
$conn = mysqli_connect($servername, $username, $password, $dbname) or die("Connection failed: " . mysqli_connect_error()); 
 
/* Database connection end */ 
 

 

 
// storing request (ie, get/post) global array to a variable 
 
$requestData= $_REQUEST; 
 

 

 
$columns = array( 
 
// datatable column index => database column name 
 
\t 0 => 'Tanggal', 
 
\t 1 => 'CustomerNo', 
 
\t 2 => 'CustomerName', 
 
\t 3 => 'Branch', 
 
\t 4 => 'Tot_Menit', 
 
\t 5 => 'Tot_call' 
 
); 
 

 
// getting total number records without any search 
 
$sql = "SELECT * "; //intensionaly * to fetch all columns 
 
$sql.=" FROM Tot_cdr_all"; 
 
$query = mysqli_query($conn, $sql); 
 
$totalData = mysqli_num_rows($query); 
 
$totalFiltered = $totalData; // when there is no search parameter then total number rows = total number filtered rows. 
 

 

 
$sql = "Select Tanggal,CustomerNo,CustomerName,Branch,sum(Tot_Menit) as Tot_Menit,sum(Tot_call) as Tot_call From Tot_cdr_all WHERE 1=1"; 
 
if(!empty($requestData['search']['value'])) { // if there is a search parameter, $requestData['search']['value'] contains search parameter 
 
\t $sql.=" AND DATE_FORMAT(Tanggal,'%Y-%m-%d') BETWEEN DATE_FORMAT('%".$requestData['search']['value']."%','%Y-%m-%d') AND DATE_FORMAT('%".$requestData['search']['value']."%','%Y-%m-%d') "; 
 
\t $sql.=" OR (UPPER(CustomerName) like UPPER('%".$requestData['search']['value']."%') OR UPPER(Branch) like UPPER('%".$requestData['search']['value']."%') OR UPPER(CustomerNo) like UPPER('%".$requestData['search']['value']."%')) "; 
 
} 
 
$sql.=" GROUP BY 1,2,3,4"; 
 
$query = mysqli_query($conn, $sql); 
 
$totalData = mysqli_num_rows($query); 
 
$sql.=" ORDER BY 1,3 LIMIT ".(empty($requestData['start']) ? 0 : $requestData['start']).", ".$requestData['length']." "; 
 
$query = mysqli_query($conn, $sql); 
 
$totalFiltered = $totalData; // when there is a search parameter then we have to modify total number filtered rows as per search result. 
 

 
$data = array(); 
 
while($row=mysqli_fetch_assoc($query)) { // preparing an array 
 
\t $nestedData=array(); 
 

 
\t foreach($row as $index=>$value) { 
 
\t \t $nestedData[$index] = $value; 
 
\t } 
 

 
\t $data[] = $nestedData; 
 
} 
 

 
$json_data = array(
 
\t \t \t "draw"   => intval($requestData['draw']), // for every request/draw by clientside , they send a number as a parameter, when they recieve a response/data they first check the draw number, so we are sending same number in draw. 
 
\t \t \t "recordsTotal" => intval($totalData), // total number of records 
 
\t \t \t "recordsFiltered" => intval($totalFiltered), // total number of records after searching, if there is no searching then totalFiltered = totalData 
 
\t \t \t "records"   => $data // total data array 
 
\t \t \t); 
 
//print_r($data); 
 

 
echo json_encode($json_data); // send data as json format 
 

 
?>
<html> 
 
<body> 
 

 
<form action="#" method="post" name="niceform" class="form-horizontal"> 
 
<div id="daterange" class="pull-left" style="margin-left: 15px"> 
 
\t \t \t \t <div id="reservation" class="input-prepend" style="background: #fff; cursor: pointer; padding: 5px 10px; border: 1px solid #ccc; width: 100%"> 
 
\t \t \t \t \t <i class="glyphicon glyphicon-calendar fa fa-calendar"></i>&nbsp; 
 
\t \t \t \t \t <span></span> <b class="caret"></b> 
 
\t \t \t \t </div> 
 
\t \t \t </div> 
 
\t \t \t <div class="pull-right" style="margin-right: 15px"> 
 
\t \t \t \t <input name="Submit" type="submit" value="Ok" class="btn btn-facebook" /> 
 
\t \t \t </div> 
 
</form> 
 

 
\t \t \t <div class="box-body"> 
 
\t \t \t \t <div class="table-responsive"> 
 
\t \t \t \t \t <table class="display" id="Show-Tables" width="100%"> 
 
\t \t \t \t \t \t <thead> 
 
\t \t \t \t \t \t \t <tr align="center"> 
 
\t \t \t \t \t \t \t \t <th><center>Tanggal</center></th> 
 
\t \t \t \t \t \t \t \t <th><center>Customer No.</center></th> 
 
\t \t \t \t \t \t \t \t <th><center>Customer Name</center></th> 
 
\t \t \t \t \t \t \t \t <th><center>Branch</center></th> 
 
\t \t \t \t \t \t \t \t <th><center>Total Menit</center></th> 
 
\t \t \t \t \t \t \t \t <th><center>Total Call</center></th> 
 
\t \t \t \t \t \t \t </tr> 
 
\t \t \t \t \t \t </thead> 
 
\t \t \t \t \t </table> 
 
\t \t \t \t </div> 
 
\t \t \t </div> 
 

 
</body> 
 
</html>

どのように私は私のDataTableをフィルタリングするdaterangepicker値を渡すことができますか?

答えて

0

私の環境であなたの日付範囲のものを再作成しましたが、マイナーチェンジしました。 データ範囲の変更イベントを追加して、データ型にajaxを強制的に実行させました。

<script type="text/javascript"> 
    $(function() 
    { 
     var startdate = moment().subtract(29, 'days'); 
     var enddate = moment(); 
     function cb(startdate, enddate) { 
      $('#reservation span').html(startdate.format('YYYY-MM-DD') + ' ~ ' + enddate.format('YYYY-MM-DD')); 

このcb関数はコールバック関数なので、私はあなたの問題の原因と考えていました。最初の呼び出しとデータ可能なajax呼び出しの間のタイミングを保証する方法はありませんでした。

この関数は、日付が変更されるたびに呼び出されるため、イベントハンドラを取り除き、これを使用してデータテーブルのajax呼び出しをトリガします。

      $('#example').DataTable().draw(); 
     } 
     $('#reservation').daterangepicker({ 
      start: startdate, 
      end: enddate, 
      ranges: { 
       'Today': [moment(), moment()], 
       'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')], 
       'Last 7 Days': [moment().subtract(6, 'days'), moment()], 
       'Last 30 Days': [moment().subtract(29, 'days'), moment()], 
       'This Month': [moment().startOf('month'), moment().endOf('month')], 
       'Last Month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')] 
      } 
     }, cb) 

上記のように、私は最初にここに入れたイベントハンドラを削除しました。

 cb(startdate, enddate); 

    }); 
</script> 

しかし、私たちも、日付を渡すために、テキストなど他のものは、検索ボックスに入力したとき、私は実際にそのイベントハンドラで日付を渡しませんしたいので。私はdatatable ajax呼び出しの日付を取得します。

<script type="text/javascript" charset="utf-8"> 
    $(document).ready(function() 
    { 
     // DataTable 
     $('#Show-Tables').DataTable({ 
      "processing": true, 
      "serverSide": true, 

遅延ロードを追加しました。つまり、データテーブルが作成されますが、データを取得するための最初の呼び出しは、他のアクションによってトリガーされるまで遅延されます。これにより、データが取得される前に日付ピッカー時間が作成されます。

      "deferLoading":0, 
      "pagingType": "full_numbers", 
      "ajax": { 
       "url": "dt-json-data.php", 
       "type": "POST", 
       //// Addded section to get the dates based on daterangepicker documentation 
       data: function (dtParms) { 
        var start = $('#reservation').data('daterangepicker').startDate.format(); 
        var end = $('#reservation').data('daterangepicker').endDate.format(); 
        // I put the dates in the search object but you can put it where you want inside the object. 
        dtParms.search.startDate = start; 
        dtParms.search.endData = end; 
        return dtParms; 
       }, 
       "dataSrc": "records" 
      }, 
      "columns": [ 
       { "data": "Tanggal" }, 
       { "data": "CustomerNo" }, 
       { "data": "CustomerName" }, 
       { "data": "Branch" }, 
       { "data": "Tot_Menit" }, 
       { "data": "Tot_call" } 
      ], 
      "autoWidth": true 
     }); 
    }); 
</script>I tested this against my environment so make sure I did not make misstates to make it fit yours. 
+0

こんにちはBindrid、あなたの提案はまだ私のスクリプトで動作していませんでした。私はあなたの提案を試している間にいくつかのエラーがあります(私はあなたのためにそれをキャプチャされた、見てください)。 –

+0

おそらくタイミングの問題です。私は、データテーブルは、その完了する前に日付範囲のオブジェクトにアクセスしようとしていると思う – Bindrid

関連する問題