将新行添加到GridView的Header中

时间:2014-04-23 16:33:54

标签: c# asp.net gridview

我在向GridView的Header添加一个带有几个控件(如textBoxes)的新行时遇到问题。当我使用...

将它们添加到GridView_RowCreated方法的Header中时
if (e.Row.RowType == DataControlRowType.Header)
        {
            GridViewRow r = new GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Normal);
            TableCell tc = new TableCell();

..他们总是排在第一排,而不是第二排。我该怎么改变它?我希望我创建的行放在第二个Header Row中。我试图自己做,首先,我将ShowHeader修改为false并以编程方式添加第一行和第二行,但这是错误的方式,特别是当网格没有要显示的数据但是有必要显示标题时。我发现了这个讨论similar discussion,但是intellisence并不了解覆盖PrepareControlHierarchy。我试图用Object浏览器搜索它,发现这是GridView的方法,但我无法插入并测试。也许有人知道更容易解决这个问题。 我需要一些帮助 已更新! enter image description here


 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
        CellPadding="4" DataKeyNames="username" DataSourceID="SqlDataSource1" 
        ForeColor="#333333" GridLines="None" onrowcreated="GridView1_RowCreated">
        <AlternatingRowStyle BackColor="White" />
        <Columns>
            <asp:TemplateField HeaderText="username" SortExpression="username">
                <ItemTemplate>
                    <asp:Label ID="Label1" runat="server" Text='<%# Bind("username") %>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Name" SortExpression="Name">
                <ItemTemplate>
                    <asp:Label ID="Label2" runat="server" Text='<%# Bind("Name") %>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Surname" SortExpression="Surname">
                <ItemTemplate>
                    <asp:Label ID="Label3" runat="server" Text='<%# Bind("Surname") %>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>




修订!!!! 是的,教授你是对的,在我看来,这是将控件放在HeaderTemplate中最简单的方法。我忘记了。但我有一个小问题,如何在不添加额外标签的情况下添加列名?这是我的代码:

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
        CellPadding="4" DataKeyNames="username" DataSourceID="SqlDataSource1" 
        ForeColor="#333333" GridLines="None" onrowcreated="GridView1_RowCreated">
        <AlternatingRowStyle BackColor="White" />
        <Columns>
            <asp:TemplateField **HeaderText="username"** SortExpression="username">
            <HeaderTemplate>
                **<asp:Label ID="Label4" runat="server" Text="username"></asp:Label>**<br />
                <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
            </HeaderTemplate>
                <ItemTemplate>
                    <asp:Label ID="Label1" runat="server" Text='<%# Bind("username") %>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Name" SortExpression="Name">
            <HeaderTemplate>
            <asp:Label ID="Label4" runat="server" Text="Name"></asp:Label><br />
                <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
            </HeaderTemplate>
                <ItemTemplate>
                    <asp:Label ID="Label2" runat="server" Text='<%# Bind("Name") %>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Surname" SortExpression="Surname">
            <HeaderTemplate>
            <asp:Label ID="Label4" runat="server" Text="Surname"></asp:Label><br />
                <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
            </HeaderTemplate>
                <ItemTemplate>
                    <asp:Label ID="Label3" runat="server" Text='<%# Bind("Surname") %>'></asp:Label>
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>

我标记了粗体字符串。如果我没有Label就离开(仅使用HeaderText =&#34;用户名&#34;),它不会在标题栏中显示任何名称。只有我添加标签,它才会显示我的名字。这有什么问题?

2 个答案:

答案 0 :(得分:2)

动态地,您必须在每个数据绑定

之后添加第二个标题行

VB中的示例,但您应该能够轻松转换它。

Private Sub GridView1_DataBound(sender As Object, e As EventArgs) Handles GridView1.DataBound

    // Add checks for row count.

    // create a new row
    Dim gvr As New GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Normal)

    Dim gvc As TableCell

    // Create a new empty cell
    gvc = New TableCell()

    //add a new TextBox to the cell
    gvc.Controls.Add(New TextBox())

    // Add the cell to the row
    gvr.Cells.Add(gvc)

    // repeat above as necessary

    // Add row to Gridview at index 1 (0 is bound header)
    // GridView1.Controls(0) is the Gridview table
    GridView1.Controls(0).Controls.AddAt(1, gvr)
End Sub

答案 1 :(得分:1)

最简单的解决方案是不要尝试在后面的代码中执行此操作。而是使用HeaderTemplate作为您的TemplateFields。

以下是一个例子:

<asp:TemplateField HeaderText="username" SortExpression="username">
    <HeaderTemplate>                              
      username
      <br />
      <asp:TextBox ID="username" runat="server" />
    </HeaderTemplate>   
    <ItemTemplate...   
</asp:TemplateField>