【发布时间】:2017-09-11 12:47:43
【问题描述】:
我正在尝试为数据表实现日期范围和年龄范围过滤器。
我已成功实施年龄过滤器。 这是小提琴:http://jsfiddle.net/7y8n0wLj/26/
这里是jquery
$.fn.dataTable.ext.search.push(function (settings, data, dataIndex) {
if ($('#range').val().indexOf("+")>=0){
var number=$('#range').val().slice(0,-1);
//alert(number);
return parseInt(data[1]) > parseInt(number || data[1]);
}else if ($('#range').val().indexOf("-")>=0){
var number=$('#range').val().split("-");
//alert(number[0]);
//alert(number[1]);
return parseInt(data[1]) >= parseInt(number[0] || data[1])
&& parseInt(data[1]) <= parseInt(number[1] || data[1]);
}
});
$('#range').on('change',table.draw);
但是当我试图实现 Daterange 和 age range 时无济于事 这是小提琴:http://jsfiddle.net/evcfespn/176/
$.fn.dataTableExt.afnFiltering.push(
function( oSettings, aData, iDataIndex ) {
var grab_daterange = $("#date_range").val();
var give_results_daterange = grab_daterange.split(" to ");
var filterstart = give_results_daterange[0];
var filterend = give_results_daterange[1];
var iStartDateCol = 5; //using column 2 in this instance
var iEndDateCol = 5;
var tabledatestart = aData[iStartDateCol];
var tabledateend= aData[iEndDateCol];
if ( filterstart === "" && filterend === "" )
{
return true;
}
else if ((moment(filterstart).isSame(tabledatestart) || moment(filterstart).isBefore(tabledatestart)) && filterend === "")
{
return true;
}
else if ((moment(filterstart).isSame(tabledatestart) || moment(filterstart).isAfter(tabledatestart)) && filterstart === "")
{
return true;
}
else if ((moment(filterstart).isSame(tabledatestart) || moment(filterstart).isBefore(tabledatestart)) && (moment(filterend).isSame(tabledateend) || moment(filterend).isAfter(tabledateend)))
{
return true;
}
return false;
});
$.fn.dataTable.ext.search.push(function (settings, data, dataIndex) {
if ($('#range').val().indexOf("+")>=0){
var number=$('#range').val().slice(0,-1);
//alert(number);
return parseInt(data[3]) > parseInt(number || data[3]);
}else if ($('#range').val().indexOf("-")>=0){
var number=$('#range').val().split("-");
//alert(number[0]);
//alert(number[1]);
return parseInt(data[3]) >= parseInt(number[0] || data[3])
&& parseInt(data[3]) <= parseInt(number[1] || data[3]);
}
});
$('#range').on('change',table.draw);
请帮忙。
【问题讨论】:
标签: javascript jquery datatables