0
我正在使用引導程序「daterangepicker」作爲根據今天,昨天,所有日期過濾表的數據表。 最初,數據庫中的所有行都加載到數據表中。從控制器傳遞數據在laravel中查看使用數據表中的「daterangepicker」過濾數據
我不需要最初從數據庫加載所有行。而是隻加載今天的數據第一個和
如果我點擊昨天它應該從數據庫中加載昨天的數據,而不是從數據表中過濾昨天的數據。
我有代碼如下:
$(document).ready(function() {
var oTable=$("#example").DataTable({ "bInfo": false,
"bLengthChange": false,
"bSort": false,
"responsive": true,
});
var startdate;
var enddate;
$('#reportrange').daterangepicker({
ranges: {
"Today": [moment(), moment()],
'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')]
},
format: 'DD/MM/YYYY',
},
function(start, end,label) {
// Parse it to a moment
var s = moment(start.toISOString());
var e = moment(end.toISOString());
startdate = s.format("YYYY-MM-DD");
enddate = e.format("YYYY-MM-DD");
});
$('#reportrange').on('apply.daterangepicker', function(ev, picker) {
startdate=picker.startDate.format('YYYY-MM-DD');
enddate=picker.endDate.format('YYYY-MM-DD');
oTable.draw();
});
$.fn.dataTableExt.afnFiltering.push(
function(oSettings, aData, iDataIndex) {
if(startdate!=undefined){
// 0 here is the column where my dates are.
//Convert to YYYY-MM-DD format from DD/MM/YYYY
var coldate = aData[2].split("/");
var d = new Date(coldate[2], coldate[1]-1 , coldate[0]);
var date = moment(d.toISOString());
date = date.format("YYYY-MM-DD");
//Remove hyphens from dates
dateMin=startdate.replace(/-/g, "");
dateMax=enddate.replace(/-/g, "");
date=date.replace(/-/g, "");
console.log(dateMin, dateMax, date);
// run through cases to filter results
if (dateMin == "" && date <= dateMax){
return true;
}
else if (dateMin =="" && date <= dateMax){
return true;
}
else if (dateMin <= date && "" == dateMax){
return true;
}
else if (dateMin <= date && date <= dateMax){
return true;
}
// all failed
return false;
}
}
)
$("#example").show();
});
<div class="input-prepend input-group" class="pull-right" style="background: #fff; cursor: pointer; padding: 5px 10px; border: 1px solid #ccc; width:auto">
<i class="glyphicon glyphicon-calendar fa fa-calendar one"></i>
<input type="text" style="width: 200px" name="reportrange" id="reportrange" class="form-control" />
<span></span> <b class="caret"></b>
</div>
\t \t \t \t \t \t \t
\t \t \t \t \t \t \t <table id="example" class="table table-striped table-bordered table-condensed" cellspacing="0" width="100%" style="display: none">
<thead>
<tr>
<th>Id</th>
<th>User</th>
<th>Created_at</th>
<th>Field</th>
<th>Status</th>
</tr>
</thead>
<tbody>
@foreach($auditMd5 as $md5r)
<tr>
<td>{{$md5r->id}}</td>
<td>{{$md5r->user}}</td>
<td>{{$md5r->created_at->format('d/m/Y')}}</td>
<td>{{$md5r->field}}</td>
<td>{{$md5r->status}}</td>
</tr>
@endforeach
</tbody>
</table>
\t \t \t \t \t \t \t
是否有可能直接使用daterangepicker從數據庫過濾的數據表。
你能告訴我們你的'web.php'文件的路線嗎?我認爲你可以完成製作'post'的路線併發送開始日期和結束日期,這樣你只能顯示選定的日期。儘管DataTable插件非常棒,但您應該通過AJAX加載所有可用數據,並告訴DataTable只繪製想要的數據。我用+ 4K行測試過它。讓我知道你是否需要幫助。 – Lvkz
你應該通過AJAX加載所有可用的數據,並告訴DataTable只繪製想要的數據..爲此,你能幫助我嗎? – Raj
當然!請參閱下面的答案。 – Lvkz