我有一個日期列,格式爲'17/03/2012'。datatables日期篩選器
我希望能夠選擇一個開始日期和結束日期,如果上面的1日期列在此日期範圍內,它將過濾該列。
以下是使用代碼IM:
Start Date: <input type="text" id="dateStart" name="dateStart" size="30">
End Date: <input type="text" id="dateend" name="dateend" size="30">
<script type="text/javascript" charset="utf-8">
$.fn.dataTableExt.afnFiltering.push(
function(oSettings, aData, iDataIndex) {
var iFini = document.getElementById('dateStart').value;
var iFfin = document.getElementById('dateend').value;
var iStartDateCol = 2;
var iEndDateCol = 2;
iFini=iFini.substring(0,2) + iFini.substring(3,5)+ iFini.substring(6,10)
iFfin=iFfin.substring(0,2) + iFfin.substring(3,5)+ iFfin.substring(6,10)
var datofini=aData[iStartDateCol].substring(0,2) + aData[iStartDateCol].substring(3,5)+ aData[iStartDateCol].substring(6,10);
var datoffin=aData[iEndDateCol].substring(0,2) + aData[iEndDateCol].substring(3,5)+ aData[iEndDateCol].substring(6,10);
if (iFini == "" && iFfin == "")
{
return true;
}
else if (iFini <= datofini && iFfin == "")
{
return true;
}
else if (iFfin >= datoffin && iFini == "")
{
return true;
}
else if (iFini <= datofini && iFfin >= datoffin)
{
return true;
}
return false;
}
);
$(function() {
// Implements the dataTables plugin on the HTML table
var $oTable= $("#example").dataTable({
"sDom": '<"top"><"clear">t<"bottom"i><"clear">',
"iDisplayLength": 20,
"oLanguage": {
"sLengthMenu": 'Show <select><option value="25">25</option><option value="50">50</option><option value="100">100</option><option value="200">200</option></select>'
},
"bJQueryUI": true,
//"sPaginationType": "full_numbers",
"aoColumns": [
null,
null,
{ "sType": "date" }
]
});
$('#dateStart, #dateend').daterangepicker(
{
dateFormat: 'dd/mm/yy',
arrows: true
}
);
/* Add event listeners to the two range filtering inputs */
$('#dateStart').keyup(function() { oTable.fnDraw(); });
$('#dateend').keyup(function() { oTable.fnDraw(); });
/* Add event listeners to the two range filtering inputs */
$('#dateStart').change(function() { oTable.fnDraw(); });
$('#dateend').change(function() { oTable.fnDraw(); });
/* Add event listeners to the two range filtering inputs */
$('#name').keyup(function() { oTable.fnDraw(); });
$('#name').change(function() { oTable.fnDraw(); });
});
</script>
任何幫助,建議在此將BVE非常有幫助。提前致謝。
我已經有這個我的代碼中,但它仍然無法正常工作。我用完整的代碼更新了我的問題。 – Codded 2012-03-20 08:52:39
@Codded所以我認爲問題是日期格式/解析。該擴展名是手動解析日期字符串,看起來像'iFini = iFini.substring(6,10)+ iFini.substring(3,5)+ iFini.substring(0,2)''。從他在那裏,他看起來像是在期待MM/DD/YYYY格式的東西。我建議你將擴展名更改爲不太嚴格的東西,也許是一個可以處理多種格式的實際解析器,例如您正在描述的解析器。我認爲原生javascript日期對象內置瞭解析方法,如果您使用的是jQueryUI - 它們的日期選擇器也是如此。 – mbeasley 2012-03-20 12:55:13
再次修改我的答案日期和ifini等過濾器正在工作,但表格只重繪自己,當我點擊排序列。當我選擇日期時,它不會開始抽籤。我使用daterangepicker插件。 – Codded 2012-03-20 15:41:40