数据表中的文本不显示在GridView中

本文关键字:GridView 显示 文本 数据表 | 更新日期: 2023-09-27 18:09:30

我正在创建一个数据表并填充其中的行/列。

然而,当我将其绑定到GridView时,我无法看到我分配给一列的文本。

代码:

        DataTable dt = new DataTable();
        dt.Columns.Add(new DataColumn("RowNumber", typeof(string)));
        dt.Columns.Add(new DataColumn("Column1", typeof(string)));
        DataRow dr = dt.NewRow();
        dr["RowNumber"] = 1;
        dr["Column1"] = "some text";
        dt.Rows.Add(dr);
        dr = dt.NewRow();
        dr["RowNumber"] = 2;
        dr["Column1"] = "more text";
        dt.Rows.Add(dr);
        dr = dt.NewRow();
        dr["RowNumber"] = 3;
        dr["Column1"] = "and more text";
        dt.Rows.Add(dr);
        Gridview2.DataSource = dt;
        Gridview2.DataBind();

gridview只显示第一列(数字1-3),但第二列的文本不显示在gridview上。

任何想法?

谢谢!

编辑:第一列gridview是在BoundField,而第二列是在TemplateFied. ItemTemplate.

   <asp:gridview ID="Gridview2" runat="server" ShowFooter="true" GridLines="None"  
            AutoGenerateColumns="false"  >
    <AlternatingRowStyle BackColor="White" ForeColor="#284775" />
    <EditRowStyle BackColor="#999999" />
    <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
    <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
    <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
    <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
    <SortedAscendingCellStyle BackColor="#E9E7E2" />
    <SortedAscendingHeaderStyle BackColor="#506C8C" />
    <SortedDescendingCellStyle BackColor="#FFFDF8" />
    <SortedDescendingHeaderStyle BackColor="#6F8DAE" />
<Columns>
<asp:BoundField DataField="RowNumber" HeaderText="#" ItemStyle-Width="30px" ItemStyle-HorizontalAlign="Center" />
<asp:TemplateField>
    <ItemTemplate>
        <asp:TextBox ID="TextBox1" runat="server" Width="300"></asp:TextBox>
    </ItemTemplate>
    <FooterStyle HorizontalAlign="Right" />
    <FooterTemplate>
     <asp:Button ID="ButtonAdd1" runat="server" Text="Add Statement" onclick="ButtonAdd1_Click" />
    </FooterTemplate>
</asp:TemplateField>
</Columns>
</asp:gridview>

数据表中的文本不显示在GridView中

您没有在gridview中使用第二列。使用另一个绑定字段,如下所示

<asp:BoundField DataField="Column1" HeaderText="#" ItemStyle-Width="30px" />

或修改模板文件如下

 <ItemTemplate>
    <asp:TextBox ID="TextBox1" Text='<%# Eval("Column1") %>'  runat="server" Width="300">     
    </asp:TextBox>
</ItemTemplate>

编辑1

你的gridview结构很奇怪,因为你有

 <FooterStyle HorizontalAlign="Right" />
<FooterTemplate>
 <asp:Button ID="ButtonAdd1" runat="server" Text="Add Statement" 
             onclick="ButtonAdd1_Click" />
</FooterTemplate>

in <asp:TemplateField>

您可以这样做标记。根据您的需求使用标签/文本框

<asp:TemplateField HeaderText="Column1">  
<ItemTemplate> 
 <asp:Label ID="lblColumn1" runat="server" Text='<%# DataBinder.Eval(Container.DataItem, "Column1")%'></asp:Label>
</ItemTemplate> </asp:TemplateField>