add scroll bar to table body

前端 未结 4 732
孤独总比滥情好
孤独总比滥情好 2020-12-07 23:16

I want to do this as easily as possible with out any additional libraries.

In my very long table I want to add a scrollbar to the tag so

相关标签:
4条回答
  • 2020-12-07 23:27

    If you don't want to wrap a table under any div:

    table{
      table-layout: fixed;
    }
    tbody{
          display: block;
        overflow: auto;
    }
    
    0 讨论(0)
  • 2020-12-07 23:42

    you can wrap the content of the <tbody> in a scrollable <div> :

    html

    ....
    <tbody>
      <tr>
        <td colspan="2">
          <div class="scrollit">
            <table>
              <tr>
                <td>January</td>
                <td>$100</td>
              </tr>
              <tr>
                <td>February</td>
                <td>$80</td>
              </tr>
              <tr>
                <td>January</td>
                <td>$100</td>
              </tr>
              <tr>
                <td>February</td>
                <td>$80</td>
              </tr>
              ...
    

    css

    .scrollit {
        overflow:scroll;
        height:100px;
    }
    

    see my jsfiddle, forked from yours: http://jsfiddle.net/VTNax/2/

    0 讨论(0)
  • 2020-12-07 23:43

    These solutions often have issues with the header columns aligning with the body columns, and may not work properly when resizing. I know you didn't want to use an additional library, but if you happen to be using jQuery, this one is really small. It supports fixed header, footer, column spanning (colspan), horizontal scrolling, resizing, and an optional number of rows to display before scrolling starts.

    jQuery.scrollTableBody (GitHub)

    As long as you have a table with proper <thead>, <tbody>, and (optional) <tfoot>, all you need to do is this:

    $('table').scrollTableBody();
    
    0 讨论(0)
  • 2020-12-07 23:44

    This is because you are adding your <tbody> tag before <td> in table you cannot print any data without <td>.

    So for that you have to make a <div> say #header with position: fixed;

     header
     {
          position: fixed;
     }
    

    make another <div> which will act as <tbody>

    tbody
    {
        overflow:scroll;
    }
    

    Now your header is fixed and the body will scroll. And the header will remain there.

    0 讨论(0)
提交回复
热议问题