HTML表格与jQuery分页

5

我正在尝试创建一个表格,当行数超过10行时,我想创建一个超链接,告诉用户继续下一页。这个概念被称为分页,但我如何使用jQuery/ JavaScript实现呢?

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
        <title>Table</title>
        <style type="text/css">
            th {
                background-color: #ddd;
            }
            th td {
                 border: 1px solid black;
            }
        </style>
    </head>
    <body>
        <table>
            <th>Heading1</th>
            <th>Heading2</th>
            <tbody>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr><td>This is td</td><td>This is td</td></tr>
                <tr></tr>
            </tbody>
        </table>
    </body>
</html>

你使用的是服务器端语言吗? - karim79
1个回答

18

如果你想看到简化的代码以便了解分页是如何工作的,除了插件外,也可以查看我为你准备的这个fiddle。

http://jsfiddle.net/29W9Q/

这段代码简单地将两个按钮(previous和next)绑定到表格的行上,以更改它们的可见性。每次单击按钮时,步骤如下:查看是否可以向前或向后移动,隐藏当前行,找到应该可见的行,向上或向下10行,然后使它们可见。其余的代码只是为了说明例子。
真正的jQuery工作是由less-thangreater-than选择器完成的::lt():gt(),用于选择要隐藏/显示的行。
var maxRows = 10;
$('.paginated-table').each(function() {
    var cTable = $(this);
    var cRows = cTable.find('tr:gt(0)');
    var cRowCount = cRows.size();

    if (cRowCount < maxRows) {
        return;
    }

    /* add numbers to the rows for visuals on the demo */
    cRows.each(function(i) {
        $(this).find('td:first').text(function(j, val) {
           return (i + 1) + " - " + val;
        }); 
    });

    /* hide all rows above the max initially */
    cRows.filter(':gt(' + (maxRows - 1) + ')').hide();

    var cPrev = cTable.siblings('.prev');
    var cNext = cTable.siblings('.next');

    /* start with previous disabled */
    cPrev.addClass('disabled');

    cPrev.click(function() {
        var cFirstVisible = cRows.index(cRows.filter(':visible'));

        if (cPrev.hasClass('disabled')) {
            return false;
        }

        cRows.hide();
        if (cFirstVisible - maxRows - 1 > 0) {
            cRows.filter(':lt(' + cFirstVisible + '):gt(' + (cFirstVisible - maxRows - 1) + ')').show();
        } else {
            cRows.filter(':lt(' + cFirstVisible + ')').show();
        }

        if (cFirstVisible - maxRows <= 0) {
            cPrev.addClass('disabled');
        }

        cNext.removeClass('disabled');

        return false;
    });

    cNext.click(function() {
        var cFirstVisible = cRows.index(cRows.filter(':visible'));

        if (cNext.hasClass('disabled')) {
            return false;
        }

        cRows.hide();
        cRows.filter(':lt(' + (cFirstVisible +2 * maxRows) + '):gt(' + (cFirstVisible + maxRows - 1) + ')').show();

        if (cFirstVisible + 2 * maxRows >= cRows.size()) {
            cNext.addClass('disabled');
        }

        cPrev.removeClass('disabled');

        return false;
    });

});

4
+1,非常有帮助。除非绝对必要,否则我不喜欢使用插件,因为我喜欢完全自定义代码,而不必使用他们制作的代码。 - chromedude
2
@chromedude 同意,虽然重新发明轮子是“不好的”,但在需要微调时,了解正在发生的事情确实有所帮助。客户不喜欢从开发人员那里得到“它不能这样做”的答案。jQuery(以及可拖动/可放置的UI类)是我使用的唯一JS库。 - Orbling
1
有没有人可以像这样编写代码 (<< 1 2 3 >>) 呢? :) 谢谢。 - Vincent
2
@user2789695:虽然直接相关,但这是一个很大的扩展,因为它不是最容易添加到这个示例中的东西。网站上几乎肯定有其他演示答案。 - Orbling

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接