Jquery tablesorter过滤器& ajax寻呼机

时间:2017-08-02 12:09:05

标签: javascript jquery json ajax tablesorter

我正在使用this tablesorter库进行排序和排序过滤表中的数据。我还使用this插件将表格分成多个页面。

由于我的表中的记录数量变得相当大,因此页面的加载速度变慢(> 60秒),所以我想通过加载表的内容来改变页面的行为。 ajax电话。

为此,我使用了此页面上的示例:https://mottie.github.io/tablesorter/docs/example-pager-ajax.html

并创建了一个单独的页面,执行查询并返回json。到目前为止,分页工作和过滤分类也很有效。

我面临的一个问题是某些列有一个“下拉”过滤器(通过向列添加class =“filter-select”)。这个下拉列表由tablesorter插件自动填充,列中包含值。

现在我已经切换到使用ajax调用加载数据,这些过滤器在最初加载页面时不再填充。当我在其他一个字段中输入一些数据时,下拉菜单就会突然填充。

为了找到问题的基础,我已经将我的代码简化为一个简单的示例,我仍然可以重现这个问题。代码如下所示:

<script type="text/javascript" src="/js/jquery-3.2.1.min.js"></script>
<link rel="stylesheet" type="text/css" href="/css/tablesorter.css?v=239319">
<script type="text/javascript" src="/js/jquery.tablesorter.combined.js"></script>

<link rel="stylesheet" href="/js/jquery.tablesorter.pager.css">
<script src="/js/jquery.tablesorter.pager.js"></script>

<TABLE id='issueTable' class="tablesorter search-table table table-striped table-bordered table-hover">
    <thead>
    <TR>
        <TH><B>Issue number</B></TH>
        <TH><B>Registered by</B></TH>
        <TH><B>Province</B></TH>
        <TH class="filter-select"><B>Departement</B></TH>
    </TR>
    </thead>
    <tbody class="rowlink">
    </tbody>
</TABLE>

<div id="pager1" class="pager">
    <form>
        <img src="/js/tablesorter_pager_images/first.png" class="first"/>
        <img src="/js/tablesorter_pager_images/prev.png" class="prev"/>
        <span class="pagedisplay" data-pager-output-filtered="{startRow:input} &ndash; {endRow} / {filteredRows} van {totalRows} meldingen"></span>
        <img src="/js/tablesorter_pager_images/next.png" class="next"/>
        <img src="/js/tablesorter_pager_images/last.png" class="last"/>
    </form>
</div>


<script>
    $(document).ready(function () {

        var table = $("#issueTable");

        var pager1Options = {

            container: $("#pager1"),
            page: 0,
            size: 20,
            pageReset: 0,
            ajaxUrl: 'meldingen.json',

            ajaxProcessing: function (data) {

                if (data && data.hasOwnProperty('rows')) {
                    var indx, r, row, c, d = data.rows,
                        // total number of rows (required)
                        total = data.total_rows,
                        // array of header names (optional)
                        headers = data.headers,
                        // cross-reference to match JSON key within data (no spaces)
                        headerXref = headers.join(',').split(','),
                        // all rows: array of arrays; each internal array has the table cell data for that row
                        rows = [],
                        // len should match pager set size (c.size)
                        len = d.length;
                    // this will depend on how the json is set up - see City0.json
                    // rows
                    for (r = 0; r < len; r++) {
                        row = []; // new row array
                        // cells
                        for (c in d[r]) {
                            if (typeof(c) === "string") {
                                // match the key with the header to get the proper column index
                                indx = $.inArray(c, headerXref);
                                // add each table cell data to row array
                                if (indx >= 0) {
                                    row[indx] = d[r][c];
                                }
                            }
                        }
                        rows.push(row); // add new row array to rows array
                    }
                    // in version 2.10, you can optionally return $(rows) a set of table rows within a jQuery object
                    return [total, rows, headers];
                }
            },
        };

        table.tablesorter({
            widgets: ['zebra', 'filter'],

        }).bind('pagerChange pagerComplete pagerInitialized pageMoved', function (e, c) {
            var msg = '"</span> event triggered, ' + (e.type === 'pagerChange' ? 'going to' : 'now on') +
                ' page <span class="typ">' + (c.page + 1) + '/' + c.totalPages + '</span>';
            $('#display')
                .append('<li><span class="str">"' + e.type + msg + '</li>')
                .find('li:first').remove();
        }).tablesorterPager(pager1Options);

    });
</script>

对于这个示例,我使用了一个简单的json文件,如下所示:

{
  "total_rows": 5,
  "headers": [
    "Issue number",
    "Registered by",
    "Province",
    "Departement"
  ],
  "rows": [
    {
      "Issue number": "914288",
      "Registered by": "Jan",
      "Province": "Utrecht",
      "Departement": "Department 1"
    },
    {
      "Issue number": "914289",
      "Registered by": "Piet",
      "Province": "Utrecht",
      "Departement": "Department 1"
    },
    {
      "Issue number": "914290",
      "Registered by": "Klaas",
      "Province": "Utrecht",
      "Departement": "Department 1"
    },
    {
      "Issue number": "914288",
      "Registered by": "Erik",
      "Province": "Utrecht",
      "Departement": "Department 2"
    },
    {
      "Issue number": "914288",
      "Registered by": "Bart",
      "Province": "Utrecht",
      "Departement": "Department 2"
    }
  ]
}

使用这个普通的JSON文件,过滤当然不会起作用,但是您可以看到“Departement”列的过滤器最初没有填充,只要您在其他任何一个中键入内容,它就会被填充列。

知道我在这里缺少什么吗?

更新2017-08-04:

我现在使用ajax请求填充过滤器。为此,我已将其添加到widgetOptions:

filter_selectSource: {
4: function (table, column, onlyAvail) {

                        $.getJSON('tablesorter_resources/filters.php?column=Department', function (data) {
                            var result = data.hasOwnProperty('options') ? data.options : false;
                            $.tablesorter.filter.buildSelect(table, column, result, true, onlyAvail);
                        });
                        }
                        return false;
                    }
                    }

但是根据文档,我应该这样做:

filter_selectSource: {
4: function (table, column, onlyAvail) {
                        console.log(table.hasInitialized);

                        // call ajax after tablesorter has initialized; this prevents
                        // multiple ajax calls during initialization
                        if (table.hasInitialized) {

                        $.getJSON('tablesorter_resources/filters.php?column=Department', function (data) {
                            var result = data.hasOwnProperty('options') ? data.options : false;
                            $.tablesorter.filter.buildSelect(table, column, result, true, onlyAvail);
                        });
                        }
                        return false;
                    }
                    }

但我看到table.hasInitialized返回false,所以当我添加该条件时,过滤器不会被填充。

我还注意到页面大小设置为30,因为我通过ajax切换到填充,即使我只是从数据库中每页真正获得20条记录,我设置大小:20。任何想法为什么会这样忽略?

1 个答案:

答案 0 :(得分:0)

默认情况下,过滤器选择使用表的内容填充下拉列表。要添加不可用的选项,请使用filter_selectSource option填充固定数量的值,或通过ajax调用直接从数据库获取数据。有关详细信息,请参阅文档中的示例。