Mam jedną kolumnę Data, sformatowaną '17/03/2012 '.datatables data filter
Chciałbym mieć możliwość wyboru daty początkowej i końcowej, a jeśli powyższa kolumna z 1 datą mieści się w tym zakresie dat, spowoduje odfiltrowanie kolumny.
Poniżej jest im kod za pomocą:
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>
Wszelkie porady pomaga na to by BVE niezwykle pomocne. Z góry dziękuję.
Mam już tego w moim kodu, ale nadal nie działa. Zaktualizowałem moje pytanie z pełnym kodem. – Codded
@Codded Więc myślę, że problem dotyczy formatu daty/parsowania. Rozszerzenie ręcznie analizuje łańcuch daty za pomocą dwóch linii, które wyglądają jak 'iFini = iFini.substring (6,10) + iFini.substring (3,5) + iFini.substring (0,2)'. Z tego, co tam ma, wygląda na to, że spodziewa się czegoś w formacie MM/DD/RRRR. Polecam zmienić rozszerzenie na coś mniej sztywnego, może rzeczywisty analizator składni, który może obsługiwać wiele formatów, takich jak ten, który opisujesz. Myślę, że obiekt daty javascript posiada wbudowaną metodę parsowania i jeśli w ogóle używasz jQueryUI - ich datepicker również. – mbeasley
Zmieniono moją odpowiedź na datę i ifini itd. Filtr działa, ale tabela sama się odrysowuje, gdy klikam, aby posortować kolumnę. Nie inicjuje losowania, gdy wybrałem datę. Korzystam z wtyczki daterangepicker. – Codded