3

我在我的一些 HTML 表中使用 jQuery DataTables。好吧,我有一个页面,我在其中列出了几个表,我必须通过相同的过滤器过滤所有这些表。在这种情况下是我自定义的日期范围。

所有的表都使用相同的 css 类来构造 dataTable 和我在日期范围内进行的搜索

$.fn.dataTableExt.afnFiltering.push(fn).

我还有另一个文本搜索,使用

$('.dataTable').dataTable().fnFilter(
    searchVal,
    4,
    false,
    true
);

这个也只能在一张桌子上工作,而不是像我期望的那样在所有桌子上工作。

谢谢,

4

1 回答 1

1

你有没有注意到这个 范围过滤(日期)

显示详细信息 筛选特定日期范围内的列。请注意,您可能需要更改输入的 id 以及存在开始和结束日期的列。

$.fn.dataTableExt.afnFiltering.push(
function( oSettings, aData, iDataIndex ) {
    var iFini = document.getElementById('fini').value;
    var iFfin = document.getElementById('ffin').value;
    var iStartDateCol = 6;
    var iEndDateCol = 7;

    iFini=iFini.substring(6,10) + iFini.substring(3,5)+ iFini.substring(0,2)
    iFfin=iFfin.substring(6,10) + iFfin.substring(3,5)+ iFfin.substring(0,2)       

    var datofini=aData[iStartDateCol].substring(6,10) + aData[iStartDateCol].substring(3,5)+ aData[iStartDateCol].substring(0,2);
    var datoffin=aData[iEndDateCol].substring(6,10) + aData[iEndDateCol].substring(3,5)+ aData[iEndDateCol].substring(0,2);

    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;
});

范围过滤(数字) 根据介于两个给定数字之间的值过滤特定的数字列。请注意,您可能需要更改输入的id和给出数值的

于 2012-10-29T01:07:26.433 回答