2017-05-29 17 views
0

Jquery Datepickerを使用してデータテーブルの生年月日の列をフィルタリングしようとしています。 しかし、私にとってはあまりにも難しいです、私はオンラインで良い例を見つけることができません。 どうすればいいのか説明してください。前もって感謝します。datepickerでデータ範囲の列を日付範囲でフィルタリングする必要があります

Screenshots

コード:

 <form class="form-inline" > 
      <div class="form-group"> 
      <label for="exampleInputEmail2">From </label> 
      <input type = "text" class="form-control" id = "datepicker1" name= "date1" placeholder="From Date"/> 
      </div> 
      <div class="form-group"> 
      <label for="exampleInputEmail2">To </label> 
      <input type = "text" class="form-control" id = "datepicker2" name= "date2" placeholder="To Date"/> 
      </div> 
     </form> 
     <table id="formdata4" class="table table-bordered table-hover nowrap"> 
       <thead> 
       <tr style="border-color:black"> 
        <th> ID </th> 
        <th> Name </i></a></th> 
        <th> Email </th> 
        <th> Age </th> 
        <th> Gender </th> 
        <th> D.O.B </th> 
        <th> Address </th> 
        <th> City </th> 
        <th> Skills </th> 
        <th> Action </th> 
       </tr> 
       </thead> 
     </table> 
    <script> 
     var table1; 
     $(document).ready(function(){ 
       //$("#datepicker1").datepicker({ dateFormat: 'yy-mm-dd', defaultDate: null }); 
       //$("#datepicker2").datepicker({ dateFormat: 'yy-mm-dd', defaultDate: null }); 
         $(function() { 
          $("#datepicker1").datepicker({dateFormat: 'yy-mm-dd'}); 
         }); 

         $(function() { 
          $("#datepicker2").datepicker({dateFormat: 'yy-mm-dd'}); 
         }); 

     table1 = $('#formdata4').dataTable({ 
           "ajax":{ 
            "url": "dataTable.php", 
            "dataSrc":"" 
            }, 
           "columns": [ 
            { "data": "user_id" }, 
            { "data": "name" }, 
            { "data": "email" }, 
            { "data": "age" }, 
            { "data": "gender" }, 
            { "data": "dob" }, 
            { "data": "address" }, 
            { "data": "city" }, 
            { "data": "skill" }, 
            { "data": "button" }, 
            ] 
           }); 

          //table1.columnFilter({ sPlaceHolder: "head:before", 
          //aoColumns: [{ type: "text" }, 
          //{ type: "date-range", sRangeFormat: "Between {from} and {to} dates" } 
          //] 
          //  }); 
          //$('#datepicker1').change(function() { table1.fnDraw(); }); 
          //$('#datepicker2').change(function() { table1.fnDraw(); });    
    }); 
        $('#datepicker1').on('change', function() {       
        $('#formdata4').dataTable().fnFilter(this.value, 5); 
        }); 
// $('#datepicker1, #datepicker2').on('change', function() { 
// var start =$('#datepicker1').val(); 
// var end =$('#datepicker2').val(); 
// table1.column(5).search(start, end).draw(); 
//}); 
       //$.datepicker.regional[""].dateFormat = 'dd/mm/yy'; 
       //$.datepicker.setDefaults($.datepicker.regional['']); 
     </script> 

すべての

答えて

0

ファーストを助けてください誰かあなたが検索ボタンをクリックしたとき、あなたは1つのボタン(検索)を追加し、日付の値を取得しに渡しますdatatable関数 たとえば、

$(document).ready(function() { 
    bindGrid('',''); 
     $("#btnID").click(function() { 
      try { 
       var parameter1 = $('#txtFromDate').val(); 
       var parameter2 = $('#txtToDate').val(); 
       bindGrid(parameter1,parameter2); 
      } catch (e) { 
      } 

     }); 
}); 

function bindGrid(parameter1,parameter2) { 
$('#formdata4').dataTable({ 
... 
"sAjaxSource": "dataTable.php", 
     "fnServerParams": function (aoData) { 
      aoData.push({ "name": "FromDate", "value": parameter1 },{"name":"ToDate","value":parameter2}); 
      perm = aoData; 
     }, 
... 
}); 
} 
+0

1つの日付で検索しているようですが、2つの日付ピッカー(日付範囲)を使って検索することを意味します – Joseph

+0

は2つのパラメータ –

+0

を渡します。 dataTableは既に正しく初期化されていますか? 、再び関数bindGridで再初期化されましたか? – Joseph

関連する問題