fixed html table header inside div

3

I have an html table inside a div with scroll in Y, inside the table I have a header that I want to be fixed, how can I make the header of the table stay fixed knowing that the table is inside a div.

    div.tableContainer {
        width: 90%; /* table width will be 99% of this*/
        height: 320px; /* must be greater than tbody*/
        overflow: auto;
        margin: 0 auto;
    }

    table {
        width: 97%; /*100% of container produces horiz. scroll in Mozilla*/
        border: none;
        border-spacing: 0px;
        background-color: transparent;
    }

        table > tbody {
            overflow: auto;
            height: 280px;
            overflow-x: hidden;
        }

            table > tbody tr {
                height: auto;
            }
<div class="tableContainer">
<table role="table">
    <thead role="rowgroup">
        <tr role="row">
            <th role="columnheader">First Name</th>
            <th role="columnheader">Last Name</th>
            <th role="columnheader">Job Title</th>
            <th role="columnheader">Favorite Color</th>
            <th role="columnheader">Wars or Trek?</th>
            <th role="columnheader">Secret Alias</th>
            <th role="columnheader">Date of Birth</th>
            <th role="columnheader">Dream Vacation City</th>
            <th role="columnheader">GPA</th>
            <th role="columnheader">Arbitrary Data</th>
        </tr>
    </thead>
    <tbody role="rowgroup">
        <tr role="row">
            <td role="cell">James</td>
            <td role="cell">Matman</td>
            <td role="cell">Chief Sandwich Eater</td>
            <td role="cell">Lettuce Green</td>
            <td role="cell">Trek</td>
            <td role="cell">Digby Green</td>
            <td role="cell">January 13, 1979</td>
            <td role="cell">Gotham City</td>
            <td role="cell">3.1</td>
            <td role="cell">RBX-12</td>
        </tr>
        <tr role="row">
            <td role="cell">The</td>
            <td role="cell">Tick</td>
            <td role="cell">Crimefighter Sorta</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">John Smith</td>
            <td role="cell">July 19, 1968</td>
            <td role="cell">Athens</td>
            <td role="cell">N/A</td>
            <td role="cell">Edlund, Ben (July 1996).</td>
        </tr>
        <tr role="row">
            <td role="cell">Jokey</td>
            <td role="cell">Smurf</td>
            <td role="cell">Giving Exploding Presents</td>
            <td role="cell">Smurflow</td>
            <td role="cell">Smurf</td>
            <td role="cell">Smurflane Smurfmutt</td>
            <td role="cell">Smurfuary Smurfteenth, 1945</td>
            <td role="cell">New Smurf City</td>
            <td role="cell">4.Smurf</td>
            <td role="cell">One</td>
        </tr>
        <tr role="row">
            <td role="cell">Cindy</td>
            <td role="cell">Beyler</td>
            <td role="cell">Sales Representative</td>
            <td role="cell">Red</td>
            <td role="cell">Wars</td>
            <td role="cell">Lori Quivey</td>
            <td role="cell">July 5, 1956</td>
            <td role="cell">Paris</td>
            <td role="cell">3.4</td>
            <td role="cell">3451</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
    </tbody>
</table>

</div>
    
asked by Ivxn 29.08.2018 в 18:19
source

2 answers

2

I suggest you review these two answers:

answered by 29.08.2018 / 22:57
source
2

I'll leave you an option

.fixedhead{
    display: table;
    width: 100%;
    table-layout: fixed;
}
.fixedbody{
    display: block;
    height: 7rem;
    overflow: auto;
    position: static;
}
<div class="tableContainer">
<table role="table">
    <thead class="fixedhead" role="rowgroup">
        <tr role="row">
            <th role="columnheader">First Name</th>
            <th role="columnheader">Last Name</th>
            <th role="columnheader">Job Title</th>
            <th role="columnheader">Favorite Color</th>
            <th role="columnheader">Wars or Trek?</th>
            <th role="columnheader">Secret Alias</th>
            <th role="columnheader">Date of Birth</th>
            <th role="columnheader">Dream Vacation City</th>
            <th role="columnheader">GPA</th>
            <th role="columnheader">Arbitrary Data</th>
        </tr>
    </thead>
    <tbody class="fixedbody" role="rowgroup">
        <tr role="row">
            <td role="cell">James</td>
            <td role="cell">Matman</td>
            <td role="cell">Chief Sandwich Eater</td>
            <td role="cell">Lettuce Green</td>
            <td role="cell">Trek</td>
            <td role="cell">Digby Green</td>
            <td role="cell">January 13, 1979</td>
            <td role="cell">Gotham City</td>
            <td role="cell">3.1</td>
            <td role="cell">RBX-12</td>
        </tr>
        <tr role="row">
            <td role="cell">The</td>
            <td role="cell">Tick</td>
            <td role="cell">Crimefighter Sorta</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">John Smith</td>
            <td role="cell">July 19, 1968</td>
            <td role="cell">Athens</td>
            <td role="cell">N/A</td>
            <td role="cell">Edlund, Ben (July 1996).</td>
        </tr>
        <tr role="row">
            <td role="cell">Jokey</td>
            <td role="cell">Smurf</td>
            <td role="cell">Giving Exploding Presents</td>
            <td role="cell">Smurflow</td>
            <td role="cell">Smurf</td>
            <td role="cell">Smurflane Smurfmutt</td>
            <td role="cell">Smurfuary Smurfteenth, 1945</td>
            <td role="cell">New Smurf City</td>
            <td role="cell">4.Smurf</td>
            <td role="cell">One</td>
        </tr>
        <tr role="row">
            <td role="cell">Cindy</td>
            <td role="cell">Beyler</td>
            <td role="cell">Sales Representative</td>
            <td role="cell">Red</td>
            <td role="cell">Wars</td>
            <td role="cell">Lori Quivey</td>
            <td role="cell">July 5, 1956</td>
            <td role="cell">Paris</td>
            <td role="cell">3.4</td>
            <td role="cell">3451</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
        <tr role="row">
            <td role="cell">Captain</td>
            <td role="cell">Cool</td>
            <td role="cell">Tree Crusher</td>
            <td role="cell">Blue</td>
            <td role="cell">Wars</td>
            <td role="cell">Steve 42nd</td>
            <td role="cell">December 13, 1982</td>
            <td role="cell">Las Vegas</td>
            <td role="cell">1.9</td>
            <td role="cell">Under the couch</td>
        </tr>
    </tbody>
</table>
</div>

This is the easiest option but it has great disadvantages; another would be very complex javascript and suddenly you can do one with flexbox but believe me it would not be a html table would be a personalization

    
answered by 29.08.2018 в 18:33