【问题标题】:Fixed header table with horizontal scrollbar and vertical scrollbar on修复了带有水平滚动条和垂直滚动条的标题表
【发布时间】:2013-02-05 08:05:14
【问题描述】:

我一直在尝试解决 html/css 粘性标题 + 滚动条的问题。我们正在创建一个程序,该程序需要在容器大小达到某个点时显示滚动条(取决于用户的分辨率)。

我在表格的第二列强制设置最小宽度,因此表格在某个点停止减小并强制容器保持在某个宽度。容器上的溢出显示水平滚动条。一切正常。一旦我为垂直滚动添加了第二个滚动条,事情就会变得一团糟。有人有解决这个问题的方法吗?我想在 .table-body 上有一个垂直滚动条,但滚动条必须在外部容器上可见。

对于固定头表有没有好的 html/css 解决方案?我一直在寻找一个星期,但只能找到这种行为的jQuery插件。

这是我当前的 HTML:

<!DOCTYPE html>
<html>
<head>
    <title>fixed header prototyping</title>
    <link rel="stylesheet" href="css/style.css">
</head>

<body>
<div class="outer-container"> <!-- absolute positioned container -->
<div class="inner-container">

    <div class="table-header">
        <table id="headertable" width="100%" cellpadding="0" cellspacing="0">
            <thead>
                <tr>
                    <th class="header-cell col1">One</th>
                    <th class="header-cell col2">Two</th>
                    <th class="header-cell col3">Three</th>
                    <th class="header-cell col4">Four</th>
                    <th class="header-cell col5">Five</th>
                </tr>
            </thead>
        </table>
    </div>

    <div class="table-body">
        <table id="bodytable" width="100%" cellpadding="0" cellspacing="0">
            <tbody>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
                <tr>
                    <td class="body-cell col1">body row1</td>
                    <td class="body-cell col2">body row2</td>
                    <td class="body-cell col3">body row2</td>
                    <td class="body-cell col4">body row2</td>
                    <td class="body-cell col5">body row2 en nog meer</td>
                </tr>
            </tbody>
        </table>
    </div>
</div>
</div>



</body>
</html>

我的 CSS 看起来像这样:

body {
    margin:0;
    padding:0;
    height: 100%;
    width: 100%;
}
table {
    border-collapse: collapse; /* make simple 1px lines borders if border defined */
}
tr {
    width: 100%;
}

.outer-container {
    background-color: #ccc;
    position: absolute;
    top:0;
    left: 0;
    right: 300px;
    bottom:40px;
    overflow: hidden;

}
.inner-container {
    width: 100%;
    height: 100%;
    position: relative;
    overflow-x: scroll;
    overflow-y:hidden;
}
.table-header {
    float:left;
    width: 100%;
}
.table-body {
    float:left;
    height: 100%;
    width: inherit;
    overflow-y: scroll;
}
.header-cell {
    background-color: yellow;
    text-align: left;
    height: 40px;
}
.body-cell {
    background-color: blue;
    text-align: left;
}
.col1, .col3, .col4, .col5 {
    width:120px;
    min-width: 120px;
}
.col2 {
    min-width: 300px;
}

JSFiddle 示例 - http://jsfiddle.net/W8URM/

提前谢谢各位!

【问题讨论】:

  • 你必须使用table吗?或者你可以使用类似div 的表格布局吗?
  • 请检查解决方案是否合适。

标签: html css header html-table fixed


【解决方案1】:

为此有一个 jquery 插件:jquery.floatThead

【讨论】:

    【解决方案2】:

    这是一个仅 HTML / CSS 的解决方案(带有一点 javascript)。

    抱歉这么久后回答这个问题,但给出的解决方案不适合我,我找到了一个更好的解决方案。这是使用 HTML(无 jquery)的最简单方法:

    在此之前,解决方案摆弄了这个问题。 https://jsfiddle.net/3vzrunkt/

    <div>
        <div style="overflow:hidden;;margin-right:16px" id="headerdiv">
            <table id="headertable" style="min-width:900px" border=1>
                <thead>
                    <tr>
                        <th style="width:120px;min-width:120px;">One</th>
                        <th style="width:420px;min-width:420px;">Two</th>
                        <th style="width:120px;min-width:120px;">Three</th>
                        <th style="width:120px;min-width:120px;">Four</th>
                        <th style="width:120px;min-width:120px;">Five</th>
                    </tr>
                </thead>
            </table>
        </div>
    
        <div style="overflow-y:scroll;max-height:200px;" 
             onscroll="document.getElementById('headerdiv').scrollLeft = this.scrollLeft;">
            <table id="bodytable" border=1 style="min-width:900px; border:1px solid">
                <tbody>
                    <tr>
                        <td style="width:120px;min-width:120px;">body row1</td>
                        <td style="width:420px;min-width:420px;">body row2</td>
                        <td style="width:120px;min-width:120px;">body row2</td>
                        <td style="width:120px;min-width:120px;">body row2</td>
                        <td style="width:120px;min-width:120px;">body row2 en nog meer</td>
                    </tr>
                    :
                    :
                    :
                    :
    
                </tbody>
            </table>
        </div>
    </div>
    

    并解释解决方案:

    1. 你需要并且封闭 div 不需要溢出/滚动

    2. 包含标题表的标题 div 带有溢出:隐藏以确保不显示滚动条。添加 margin-right:16px 以确保同步时滚动条位于其外部。

    3. 另一个 div 用于包含表记录和溢出-y:scroll。请注意,要使滚动条向右移动标题,需要填充。

    4. 还有最重要的是神奇的js同步表头数据:

       onscroll="document.getElementById('headerdiv').scrollLeft = this.scrollLeft;"
      

    【讨论】:

    • 好主意,虽然我想要一个只使用这样的表格的替代方案
    • 是否有可能扩展您的解决方案(没有 jQuery)也可以修复列(最后一个或第一个)?我试图设置位置:绝对但它是不可滚动的..
    • Cheers mate as css only solution 这就像一个魅力。
    • @Anshuman 想知道您是否可以帮助解决我的问题版本:stackoverflow.com/questions/47073223/…?谢谢。
    • 这不是仅 HTML/CSS 的解决方案,您有一个 onscroll,它是 JavaScript。
    【解决方案3】:

    解决办法是用JS水平滚动顶部div,使其匹配底部div。

    您必须非常小心确保顶部和底部的尺寸完全相同,例如您可能需要使 TD 和 TH 使用固定宽度。

    这是一个小提琴https://jsfiddle.net/jdhenckel/yzjhk08h/5/

    重要部分:CSS 使用

    .head {
      overflow-x: hidden;
      overflow-y: scroll;
      width: 500px;
    }
    .lower {
      overflow-x: auto;
      overflow-y: scroll;
      width: 500px;
      height: 400px;
    }
    

    注意overflow-y的头部和下部必须相同。

    还有 Javascript...

    var head = document.querySelector('.head');
    
    var lower = document.querySelector('.lower');
    
    lower.addEventListener('scroll', function (e) {
      console.log(lower.scrollLeft);
      head.scrollLeft = lower.scrollLeft;
    });
    

    【讨论】:

      【解决方案4】:

      这是一个不是纯 CSS 的解决方案的解决方案。它与avrahamcool's solution 相似,因为它使用几行jQuery,但不是改变高度和移动标题,它所做的只是根据其父table 滚动的距离来改变tbody 的宽度沿着右边。

      此解决方案的另一个好处是它可以与语义上有效的 HTML 表格一起使用

      它适用于所有最新的浏览器版本(IE10、Chrome、FF),仅此而已,滚动功能在旧版本上会中断。

      但是,您使用语义上有效的 HTML 表格这一事实将节省时间并确保表格仍然正确显示,只是滚动功能在旧版浏览器上不起作用。

      这是一个 jsFiddle 用于演示目的。

      CSS

      table {
          width: 300px;
          overflow-x: scroll;
          display: block;
      }
      thead, tbody {
          display: block;
      }
      tbody {
          overflow-y: scroll;
          overflow-x: hidden;
          height: 140px;
      }
      td, th {
          min-width: 100px;
      }
      

      JS

      $("table").on("scroll", function () {
          $("table > *").width($("table").width() + $("table").scrollLeft());
      });
      

      我需要一个在 IE9 中可以很好地降级的版本(没有滚动,只是一个普通的表格)。在这里发布小提琴,因为它是一个改进的版本。您需要做的就是在tr 上设置一个高度。

      额外的 CSS 使该解决方案在 IE9 中很好地降级

      tr {
          height: 25px; /* This could be any value, it just needs to be set. */ 
      }
      

      这是一个 jsFiddle 演示了该解决方案在 IE9 版本中的良好降级。

      编辑:更新了小提琴链接以链接到包含对 cme​​ts 中提到的问题的修复的小提琴版本。只需添加一个带有最新和最好版本的 sn-p:

      $('table').on('scroll', function() {
        $("table > *").width($("table").width() + $("table").scrollLeft());
      });
      html {
        font-family: verdana;
        font-size: 10pt;
        line-height: 25px;
      }
      
      table {
        border-collapse: collapse;
        width: 300px;
        overflow-x: scroll;
        display: block;
      }
      
      thead {
        background-color: #EFEFEF;
      }
      
      thead,
      tbody {
        display: block;
      }
      
      tbody {
        overflow-y: scroll;
        overflow-x: hidden;
        height: 140px;
      }
      
      td,
      th {
        min-width: 100px;
        height: 25px;
        border: dashed 1px lightblue;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 100px;
      }
      <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
      <table>
        <thead>
          <tr>
            <th>Column 1</th>
            <th>Column 2</th>
            <th>Column 3</th>
            <th>Column 4</th>
            <th>Column 5</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td>AAAAAAAAAAAAAAAAAAAAAAAAAA</td>
            <td>Row 1</td>
            <td>Row 1</td>
            <td>Row 1</td>
            <td>Row 1</td>
          </tr>
          <tr>
            <td>Row 2</td>
            <td>Row 2</td>
            <td>Row 2</td>
            <td>Row 2</td>
            <td>Row 2</td>
          </tr>
          <tr>
            <td>Row 3</td>
            <td>Row 3</td>
            <td>Row 3</td>
            <td>Row 3</td>
            <td>Row 3</td>
          </tr>
          <tr>
            <td>Row 4</td>
            <td>Row 4</td>
            <td>Row 4</td>
            <td>Row 4</td>
            <td>Row 4</td>
          </tr>
          <tr>
            <td>Row 5</td>
            <td>Row 5</td>
            <td>Row 5</td>
            <td>Row 5</td>
            <td>Row 5</td>
          </tr>
          <tr>
            <td>Row 6</td>
            <td>Row 6</td>
            <td>Row 6</td>
            <td>Row 6</td>
            <td>Row 6</td>
          </tr>
          <tr>
            <td>Row 7</td>
            <td>Row 7</td>
            <td>Row 7</td>
            <td>Row 7</td>
            <td>Row 7</td>
          </tr>
          <tr>
            <td>Row 8</td>
            <td>Row 8</td>
            <td>Row 8</td>
            <td>Row 8</td>
            <td>Row 8</td>
          </tr>
          <tr>
            <td>Row 9</td>
            <td>Row 9</td>
            <td>Row 9</td>
            <td>Row 9</td>
            <td>Row 9</td>
          </tr>
          <tr>
            <td>Row 10</td>
            <td>Row 10</td>
            <td>Row 10</td>
            <td>Row 10</td>
            <td>Row 10</td>
          </tr>
        </tbody>
      </table>

      【讨论】:

      • 非常简单和非常好的解决方案:),但是如果您需要在同一页面上使用两个或多个表,您可以实现以下代码:$(window).load(function(){ $('table').on('scroll', function () { $(this).find(" &gt; *").width($(this).width() + $(this).scrollLeft()); }); }); 非常感谢 Mathijs 的想法。
      • 我非常希望它能够完美运行,不幸的是,如果您在 IE 10 和 11 中单击滚轮进行鼠标移动滚动,它会在身体而不是头部进行水平滚动,并且不会'甚至不更新滚动条。关于如何解决这个问题的任何想法?
      • 相同的解决方案,但没有多余的 CSS(演示 CSS 解决方案时的小可爱)jsfiddle.net/oozL98dx
      • 在您的内容 > 100px 宽之前,这非常有效。那么TH宽度与对应的TD宽度不匹配。
      • @ebigood - 响应有点晚了 :) 但为了完成这项工作,您还必须稍微交换一下数学:jsfiddle.net/fp9jra43
      【解决方案5】:

      这已经让我发疯了好几个星期。我找到了一个适合我的解决方案,包括:

      1. 非固定列宽 - 它们会随着窗口大小的调整而缩小和增长。
      2. 表格在需要时有水平滚动条,但在不需要时没有。
      3. 列数无关紧要 - 它会根据您的需要调整到多少列。
      4. 并非所有列都需要具有相同的宽度。
      5. 标题一直到右侧滚动条的末尾。
      6. 没有javascript!

      ...但有几点需要注意:

      1. 在您一直向右滚动之前,垂直滚动条不可见。鉴于大多数人都有滚轮,这是可以接受的牺牲。

      2. 必须知道滚动条的宽度。在我的网站上,我设置了滚动条的宽度(我不太关心旧的、不兼容的浏览器),因此我可以计算 divtable 根据滚动条调整的宽度。

      我不会在这里发布我的代码,而是发布一个指向 jsFiddle 的链接。

      Fixed header table + scroll left/right.

      【讨论】:

        【解决方案6】:

        您可以使用以下 CSS 代码..

        body {
            margin:0;
            padding:0;
            height: 100%;
            width: 100%;
        }
        table {
            border-collapse: collapse; /* make simple 1px lines borders if border defined */
        }
        tr {
            width: 100%;
        }
        
        .outer-container {
            background-color: #ccc;    
            top:0;
            left: 0;
            right: 300px;
            bottom:40px;
            overflow:hidden;
        
        }
        .inner-container {
            width: 100%;
            height: 100%;
            position: relative;
        
        }
        .table-header {
            float:left;
            width: 100%;
        }
        .table-body {
            float:left;
            height: 100%;
            width: inherit;
        
        }
        .header-cell {
            background-color: yellow;
            text-align: left;
            height: 40px;
        }
        .body-cell {
            background-color: blue;
            text-align: left;
        }
        .col1, .col3, .col4, .col5 {
            width:120px;
            min-width: 120px;
        }
        .col2 {
            min-width: 300px;
        }
        

        【讨论】:

          【解决方案7】:

          working example in jsFiddle

          这可以使用 div 来实现。也可以用桌子来完成。但我总是更喜欢div。

          <body id="doc-body" style="width: 100%; height: 100%; overflow: hidden; position: fixed" onload="InitApp()"> 
              <div>
                  <!--If you don't need header background color you don't need this div.-->
                  <div id="div-header-hack" style="height: 20px; position: absolute; background-color: gray"></div>
          
                  <div id="div-header" style="position: absolute; top: 0px; overflow: hidden; height: 20px; background-color: gray">                
                  </div>
          
                  <div id="div-item" style="position: absolute; top: 20px; overflow: auto" onscroll="ScrollHeader()">                
                  </div>
              </div>
          </body>
          

          Javascript:
          这部分请参考 jsFiddle。否则这个答案会变得很冗长。

          【讨论】:

          • @user1386906 您可以将自己的样式添加到网格单元格和行。
          【解决方案8】:

          如果这是你想要的只有 HTML 和 CSS 解决方案

          fiddle

          这是 HTML

          <div class="outer-container"> <!-- absolute positioned container -->
          <div class="inner-container">
          
              <div class="table-header">
                  <table id="headertable" width="100%" cellpadding="0" cellspacing="0">
                      <thead>
                          <tr>
                              <th class="header-cell col1">One</th>
                              <th class="header-cell col2">Two</th>
                              <th class="header-cell col3">Three</th>
                              <th class="header-cell col4">Four</th>
                              <th class="header-cell col5">Five</th>
                          </tr>
                      </thead>
                  </table>
              </div>
          
              <div class="table-body">
                  <table id="bodytable" width="100%" cellpadding="0" cellspacing="0">
                      <tbody>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                          <tr>
                              <td class="body-cell col1">body row1</td>
                              <td class="body-cell col2">body row2</td>
                              <td class="body-cell col3">body row2</td>
                              <td class="body-cell col4">body row2</td>
                              <td class="body-cell col5">body row2 en nog meer</td>
                          </tr>
                      </tbody>
                  </table>
              </div>
          </div>
          </div>
          

          这是css

          body {
          margin:0;
          padding:0;
          height: 100%;
          width: 100%;
          }
          table {
              border-collapse: collapse; /* make simple 1px lines borders if border defined */
          }
          tr {
              width: 100%;
          }
          
          .outer-container {
              background-color: #ccc;
              position: absolute;
              top:0;
              left: 0;
              right: 300px;
              bottom:40px;
              overflow: scroll;
          
          }
          .inner-container {
              width: 100%;
              height: 100%;
              position: relative;
              overflow-x: visible;
              overflow-y:visible;
          }
          .table-header {
              float:left;
              width: 100%;
          }
          .table-body {
              float:left;
              height: auto;
              width: auto;
              overflow: visible;
              background-color: red;
          }
          .header-cell {
              background-color: yellow;
              text-align: left;
              height: 40px;
          }
          .body-cell {
              background-color: transparent;
              text-align: left;
          }
          .col1, .col3, .col4, .col5 {
              width:120px;
              min-width: 120px;
          }
          .col2 {
              min-width: 300px;
          }
          

          如果这是您需要的,请告诉我。或者有些东西不见了。我浏览了其他答案,发现已经使用了 jquery。我假设您需要 css 解决方案。如果我还有遗漏,请提及:)

          【讨论】:

          • 我认为你在这里错过了一件大事,标题没有粘住。
          【解决方案9】:

          这不是一件容易的事。 我想出了一个脚本解决方案。 (我不认为这可以使用纯 CSS 来完成)

          HTML 与您发布的内容保持一致,CSS 略有变化,添加了 JQuery 代码。

          Working Fiddle 测试于: IE10、IE9、IE8、FF、Chrome

          顺便说一句:如果您有独特的元素,为什么不使用 id 而不是类? 我认为它提供了更好的选择器性能。

          解释它的工作原理: inner-container 将跨越 outer-container 的整个空间(所以基本上不需要他)但我把他留在那里,所以你不需要改变你的 DOM。

          table-header是相对定位的,没有滚动条(overflow: hidden),我们稍后处理他的滚动条。

          table-body 必须跨越其余的inner-container 高度,所以我使用脚本来确定修复他的高度。 (当您重新调整窗口大小时,它会动态变化) 没有固定高度,滚动不会出现,因为 div 只会变大。 请注意,如果您修复标题高度并使用CSS3(如答案末尾所示),则此部分可以在没有脚本的情况下完成

          现在只需在每次滚动时将标题与正文一起移动。 这是由分配给scroll 事件的函数完成的。

          CSS(其中一些是从您的样式中复制而来的)

          *
          {
              padding: 0;
              margin: 0;
          }
          
          body
          {
              height: 100%;
              width: 100%;
          }
          table
          {
              border-collapse: collapse; /* make simple 1px lines borders if border defined */
          }
          .outer-container
          {
              background-color: #ccc;
              position: absolute;
              top:0;
              left: 0;
              right: 300px;
              bottom: 40px;
          }
          
          .inner-container
          {
              height: 100%;
              overflow: hidden;
          }
          
          .table-header
          {
              position: relative;
          }
          .table-body
          {
              overflow: auto;
          }
          
          .header-cell
          {
              background-color: yellow;
              text-align: left;
              height: 40px;
          }
          .body-cell 
          {
              background-color: blue;
              text-align: left;
          }
          .col1, .col3, .col4, .col5
          {
              width:120px;
              min-width: 120px;
          }
          .col2
          {
              min-width: 300px;
          }
          

          JQuery

          $(document).ready(function () {
              setTableBody();
              $(window).resize(setTableBody);
              $(".table-body").scroll(function ()
              {
                  $(".table-header").offset({ left: -1*this.scrollLeft });
              });
          });
          
          function setTableBody()
          {
              $(".table-body").height($(".inner-container").height() - $(".table-header").height());
          }
          

          如果您不关心修复标题高度(我看到您在 CSS 中修复了单元格的高度),如果您使用 CSS3 可以跳过某些脚本:Shorter Fiddle(这在 IE8 上不起作用)

          【讨论】:

          • 点赞!我同意你的观点,这是纯 CSS 无法实现的。恕我直言,您的解决方案正是所要求的。原始标记在语义上已经不是很明确了,因为拆分表的 theadtbody,加上将每个表包装在 DIV 中对我来说看起来并不“正确”。
          • 我的页面中也有类似的工具,但有一个问题困扰着我:如何处理 rtl 方向的页面,scrollLeft 不再适用?
          • @Zen 不用多想,我想说你可以用right: -1*this.scrollRight 替换left: -1*this.scrollLeft。发布一个相关的小提琴,我们将从那里继续。
          • @kikovi 您的演示效果不佳。标题隐藏了第一行内容,滚动时我们可以透过标题看到,只有滚动到底部才能看到底部滚动。
          • @avrahamcool 你是对的。我没有完全完善这个演示,因为它已经适合我的需要了。这是完善的版本,如果有人需要的话:jsfiddle.net/kq1gzzmm。底部滚动取决于容器高度,并且标题设置为相对位置,因此它不会隐藏第一个内容行。
          猜你喜欢
          • 1970-01-01
          • 2020-09-28
          • 2016-05-28
          • 1970-01-01
          • 2013-11-05
          • 1970-01-01
          • 2012-11-14
          • 1970-01-01
          • 2011-05-10
          相关资源
          最近更新 更多