I have an ASP.NET Panel that has a gridview inside of it. Below is the markup for it:
<asp:Panel runat="server" ID="searchResultsPanel" CssClass="datagrid" ClientIDMode="Static" style="display:none; max-height:500px; max-width:700px; overflow:auto;" >
<asp:GridView runat="server" ID="gridMemberInfo" AutoGenerateColumns="false" EmptyDataText="No Members Were Found." OnRowCommand="Command_SearchGrid" ShowHeader="true" ShowHeaderWhenEmpty="true" >
<PagerSettings Visible="false" />
<AlternatingRowStyle CssClass="alt" />
<Columns>
<asp:ButtonField ButtonType="Link" Text="Select" CommandName="SelectRow" />
<asp:BoundField HeaderText="PMI" DataField="PMI" />
<asp:BoundField HeaderText="Product" DataField="Product" ItemStyle-Width="110px" />
<asp:BoundField HeaderText="County" DataField="County" />
<asp:BoundField HeaderText="Last Name" DataField="LastName" />
<asp:BoundField HeaderText="First Name" DataField="FirstName" />
<asp:BoundField HeaderText="Currently Enrolled" DataField="CurrentlyEnrolled" ItemStyle-Width="50px" />
</Columns>
</asp:GridView>
</asp:Panel>
I have the following CSS for the panel and gridview:
.datagrid table
{
border-collapse: collapse;
text-align: left;
width: 100%;
}
.datagrid
{
font: normal 12px/150% Arial, Helvetica, sans-serif;
background: #fff;
overflow: hidden;
border: 2px solid #006699;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
}
.datagrid table td, .datagrid table th
{
padding: 3px 10px;
}
.datagrid table thead th
{
background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #00A2F2), color-stop(1, #002C42) );
background:-moz-linear-gradient( center top, #00A2F2 5%, #002C42 100% );
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00A2F2', endColorstr='#002C42');
background-color:#00A2F2;
color:#FFFFFF;
font-size: 12px;
font-weight: bold;
border: none;
}
.datagrid table thead th:first-child
{
border: 3px;
}
.datagrid table tbody td
{
color: #00496B;
font-size: 12px;
font-weight: normal;
}
.datagrid table tbody .alt td
{
background: #E1EEF4;
color: #00496B;
}
.datagrid table tbody td:first-child
{
border-left: none;
}
.datagrid table tbody tr:last-child td
{
border-bottom: none;
}
In order for the gridview to render with thead elements, I do this in the code behind: this.gridMemberInfo.HeaderRow.TableSection = TableRowSection.TableHeader;
Since I have the panel’s overflow set to auto, I can scroll when the gridview has alot of rows. What I would like to do now is make the header row fixed so that I can always see it while scrolling. I have tried setting position:fixed; in the .datagrid table thead th CSS class but that hasn’t worked. I have tried several other options and no luck. Can someone help me out with this?
You cannot do that on IE, since thead is not regarded with there css interpreter. you will need to implement a wapping div that will hold your headers. or use ones that did it before : http://www.scientificpsychic.com/blogentries/html-and-css-scrolling-table-with-fixed-heading.html
or you can take a look at:
http://demos.devexpress.com/ASPxGridViewDemos/PagingAndScrolling/Scrolling.aspx
taken from stack answer : Fixed GridView Header with horizontal and vertical scrolling in asp.net