日期:2012-09-05  浏览次数:21216 次

开发一个asp.net项目的过程中,客户要求我们,把所有datagrid表格的Header做成类似Excel表格,当table中数据很多的时候,我们可以下拉滚动条,还能保持header固定。在网上搜索后找到了如下比较简单的方法。具体应用如下:
1. 在CSS 中添加一个Class
.fixHeaderStyle {
font-size: 9pt;
vertical-align: middle;
text-transform: capitalize;
font-family: "Arial" , "Helvetica" , "sans-serif";
height: 25px;
background-color: #ecf4fe;
text-align: center;
text-decoration: none;
POSITION: relative; --必要的
TOP: expression(this.offsetParent.scrollTop) --必要的
}

在页面上,类似代码如:
<DIV style="OVERFLOW: auto; WIDTH: 100%; HEIGHT: 300px" align="center">
<asp:DataGrid id=grdCurRateVoy runat="server" Width="100%" Visible="True">
<ItemStyle CssClass="ItemStyle"></ItemStyle>
<HeaderStyle CssClass="fixHeaderStyle"></HeaderStyle>
<PagerStyle CssClass="PagerStyle"></PagerStyle>
</asp:DataGrid>
</DIV>
这就搞定了。