为什么我的网格视图在编辑了一些网格视图后消失了

本文关键字:视图 网格 消失了 编辑 我的 为什么 | 更新日期: 2023-09-27 18:25:41

我正在尝试删除网格视图中的一些列。然后这个方法是由我尝试的人提供的

protected void yourGrid_RowCreated(object sender, GridViewRowEventArgs e)
{
    e.Row.Cells[7].Visible = false;
    e.Row.Cells[8].Visible = false;
    e.Row.Cells[9].Visible = false;
}

GWCase.DataSource = ds;
GWCase.DataBind();
GWCase.Columns[7].Visible = false;
GWCase.Columns[8].Visible = false;
GWCase.Columns[9].Visible = false;

gridview和SQL server的绑定是在页面加载时完成的。这就是我的页面加载看起来像的样子

protected void Page_Load(object sender, EventArgs e)
{
    SqlConnection conn = new SqlConnection();
    conn.ConnectionString = "Data Source = localhost; Initial Catalog = MajorProject; Integrated Security= SSPI";
    conn.Open();
    DataSet ds = new DataSet();
    SqlDataAdapter da = new SqlDataAdapter("SELECT memberreportid, typeofcrime, crdatetime, address, detail, incidentdate, incidenttime, property, victim, suspect from memberreport", conn);
    da.Fill(ds);
    GWCase.DataSource = ds;
    GWCase.DataBind();
    conn.Close();
    ddlpid1.Visible = false;
    ddlpid2.Visible = false;
    ddlpid3.Visible = false;
    ddlpid4.Visible = false;
    ddlpid5.Visible = false;
    ddlpid6.Visible = false;
    ddlpid7.Visible = false;
    ddlpid8.Visible = false;
    ddlpid9.Visible = false;
    ddlpid10.Visible = false;
}

在那里,我试图更改

EventArgs to GridViewRowEventArgs.

我运行了代码,但它不起作用,事实上我的悲伤消失了。我去把它改回原来的事件参数,但网格视图仍然消失了。

这是我的gridview 的源代码

<asp:GridView ID="GWCase" runat="server" BackColor="#CCCCCC" BorderColor="#999999" BorderStyle="Solid" BorderWidth="3px" CellPadding="4" CellSpacing="2" ForeColor="Black" Width="100%" AutoGenerateSelectButton="True" OnSelectedIndexChanged="GWCase_SelectedIndexChanged">
    <FooterStyle BackColor="#CCCCCC" />
    <HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
    <PagerStyle BackColor="#CCCCCC" ForeColor="Black" HorizontalAlign="Left" />
    <RowStyle BackColor="White" />
    <SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
    <SortedAscendingCellStyle BackColor="#F1F1F1" />
    <SortedAscendingHeaderStyle BackColor="#808080" />
    <SortedDescendingCellStyle BackColor="#CAC9C9" />
    <SortedDescendingHeaderStyle BackColor="#383838" />
</asp:GridView>

更改EventArgs似乎会导致整个网格视图失败。我删除了我的aspx页面,重新创建并复制了相同的代码,网格视图仍然消失了。

为什么我的网格视图在编辑了一些网格视图后消失了

如果您想更多地控制哪些列被呈现到GridView,那么您可以使用GridViewColumns属性,如下所示:

<asp:GridView ID="GWCase" runat="server" BackColor="#CCCCCC" BorderColor="#999999" BorderStyle="Solid" BorderWidth="3px" CellPadding="4" CellSpacing="2" ForeColor="Black" Width="100%" AutoGenerateSelectButton="True" OnSelectedIndexChanged="GWCase_SelectedIndexChanged">
    <FooterStyle BackColor="#CCCCCC" />
    <HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
    <PagerStyle BackColor="#CCCCCC" ForeColor="Black" HorizontalAlign="Left" />
    <RowStyle BackColor="White" />
    <SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
    <SortedAscendingCellStyle BackColor="#F1F1F1" />
    <SortedAscendingHeaderStyle BackColor="#808080" />
    <SortedDescendingCellStyle BackColor="#CAC9C9" />
    <SortedDescendingHeaderStyle BackColor="#383838" />
    <Columns>
      <asp:BoundField datafield="CustomerID" headertext="Customer ID"/>
      <asp:BoundField datafield="CompanyName" headertext="Company Name"/>
      <asp:BoundField datafield="Address" headertext="Address"/>
      <asp:BoundField datafield="City" headertext="City"/>
      <asp:BoundField datafield="PostalCode" headertext="Postal Code"/>
      <asp:BoundField datafield="Country" headertext="Country"/>
    </Columns>
</asp:GridView>

注意:因此,您不需要使用GWCase.Columns[7].Visible = false;语法来隐藏列,而是在Columns部分中不将该列定义为绑定到GridView