<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="FixtableHeader.aspx.cs"
Inherits="Text.FixtableHeader" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript" language="javascript">
function FixTableHeader() {
var t = document.getElementById("table");
var thead = t.getElementsByTagName("thead")[0];
var t1 = t.cloneNode(false);
t1.appendChild(thead);
document.getElementById("tableHeader").appendChild(t1)
}
window.onload = FixTableHeader;
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="tableHeader">
</div>
<div style="overflow: scroll; height: 100px; width: 500px">
<table id="table" width="500" style="table-layout: fixed">
<thead>
<tr id="thead" style="background-color: #BEBEBE">
<th>
Account Number
</th>
<th>
Account Name
</th>
<th>
City
</th>
<th>
Country
</th>
</tr>
</thead>
<tbody>
<asp:Repeater ID="Reapeter1" runat="server">
<ItemTemplate>
<tr>
<td>
<%#DataBinder.Eval(Container.DataItem, "AccountNumber")%>
</td>
<td>
<%#DataBinder.Eval(Container.DataItem, "AccountName")%>
</td>
<td>
<%#DataBinder.Eval(Container.DataItem,"City")%>
</td>
<td>
<%#DataBinder.Eval(Container.DataItem,"Country")%>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
</tbody>
</table>
</div>
</form>
</body>
</html>
如果你想表头和表身的每一列都对齐的话,table的style="table-layout: fixed"不能少。
C#后台代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
namespace Text
{
public partial class FixtableHeader : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
DataTable dt = new DataTable();
dt.Columns.Add(new DataColumn("AccountNumber"));
dt.Columns.Add(new DataColumn("AccountName"));
dt.Columns.Add(new DataColumn("City"));
dt.Columns.Add(new DataColumn("Country"));
DataRow dr = dt.NewRow();
dr["AccountName"] = "Test1";
dr["AccountNumber"] = "001";
dr["Country"] = "China";
dr["City"] = "Beijing";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["AccountName"] = "Test2";
dr["AccountNumber"] = "002";
dr["Country"] = "China";
dr["City"] = "Shanghai";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["AccountName"] = "Test3";
dr["AccountNumber"] = "003";
dr["Country"] = "the Nederlands";
dr["City"] = "Amsterdam";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["AccountName"] = "Test4";
dr["AccountNumber"] = "004";
dr["Country"] = "France";
dr["City"] = "Paris";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["AccountName"] = "Test5";
dr["AccountNumber"] = "005";
dr["Country"] = "Spain";
dr["City"] = "Barcelona";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["AccountName"] = "Test6";
dr["AccountNumber"] = "006";
dr["Country"] = "China";
dr["City"] = "Shanghai";
dt.Rows.Add(dr);
Reapeter1.DataSource = dt;
Reapeter1.DataBind();
}
}
}
}
GridView表头的固定
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="GridViewFixHeader.aspx.cs" Inherits="Text.GridViewFixHeader" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title></title>
<script src="jquery-1.4.4.min.js" type="text/javascript"></script>
<script src="ScrollableGridPlugin.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function()
{ $('#<%=gvwList.ClientID %>').Scrollable({ ScrollHeight: 100 }); });
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView runat="server" ID="gvwList" AutoGenerateColumns="false">
<RowStyle BackColor="#EFF3FB" />
<FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" />
<HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
<AlternatingRowStyle BackColor="White" />
<Columns>
<asp:BoundField DataField="a" HeaderText="a"></asp:BoundField>
<asp:BoundField DataField="b" HeaderText="b"></asp:BoundField>
<asp:BoundField DataField="c" HeaderText="c"></asp:BoundField>
<asp:BoundField DataField="d" HeaderText="d"></asp:BoundField>
<asp:BoundField DataField="e" HeaderText="e"></asp:BoundField>
<asp:BoundField DataField="f" HeaderText="f"></asp:BoundField>
<asp:BoundField DataField="j" HeaderText="j"></asp:BoundField>
<asp:BoundField DataField="h" HeaderText="h"></asp:BoundField>
<asp:BoundField DataField="g" HeaderText="g"></asp:BoundField>
<asp:BoundField DataField="i" HeaderText="i"></asp:BoundField>
</Columns>
</asp:GridView>
</div>
</form>
</body>
</html>
后台
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
namespace Text
{
public partial class GridViewFixHeader : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
DataTable tab = new DataTable();
tab.Columns.Add("a", Type.GetType("System.String"));
tab.Columns.Add("b", Type.GetType("System.String"));
tab.Columns.Add("c", Type.GetType("System.String"));
tab.Columns.Add("d", Type.GetType("System.String"));
tab.Columns.Add("e", Type.GetType("System.String"));
tab.Columns.Add("f", Type.GetType("System.String"));
tab.Columns.Add("g", Type.GetType("System.String"));
tab.Columns.Add("h", Type.GetType("System.String"));
tab.Columns.Add("i", Type.GetType("System.String"));
tab.Columns.Add("j", Type.GetType("System.String"));
for (int i = 0; i < 35; i++)
{
DataRow dr = tab.NewRow();
dr["a"] = string.Format("row:{0} columns:a", i.ToString().PadLeft(2, '0'));
dr["b"] = string.Format("row:{0} columns:b", i.ToString().PadLeft(2, '0'));
dr["c"] = string.Format("row:{0} columns:c", i.ToString().PadLeft(2, '0'));
dr["d"] = string.Format("row:{0} columns:d", i.ToString().PadLeft(2, '0'));
dr["e"] = string.Format("row:{0} columns:e", i.ToString().PadLeft(2, '0'));
dr["f"] = string.Format("row:{0} columns:f", i.ToString().PadLeft(2, '0'));
dr["g"] = string.Format("row:{0} columns:g", i.ToString().PadLeft(2, '0'));
dr["h"] = string.Format("row:{0} columns:h", i.ToString().PadLeft(2, '0'));
dr["i"] = string.Format("row:{0} columns:i", i.ToString().PadLeft(2, '0'));
dr["j"] = string.Format("row:{0} columns:j", i.ToString().PadLeft(2, '0'));
tab.Rows.Add(dr);
}
// Data bind method.
gvwList.DataSource = tab;
gvwList.DataBind();
}
}
}