zoukankan      html  css  js  c++  java
  • Repeat GridView 控件的表头的固定


    <%@ 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;  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();
            }
        }
    }
    
  • 相关阅读:
    Python全栈开发:socket
    Python全栈开发:线程、进程和协程
    Python全栈开发:基本数据类型
    Python全栈开发:运算符
    使用pyplot和seaborn进行画图
    数据预处理之缺失值的处理
    数据预处理之标准化
    数据预处理之离散化
    集成学习中的 stacking 以及python实现
    使用sklearn进行交叉验证
  • 原文地址:https://www.cnblogs.com/nanxiaoxiang/p/2730500.html
Copyright © 2011-2022 走看看