在列表视图中单击按钮时绑定网格视图

binding grid view on button click in listview

我有一个列表视图,每行都有一个按钮:

 <td> <asp:Button ID="Button2" runat="server" Text="select" CommandName="view" CommandArgument='<%# Eval("inquiry_id")%>'   onclick="buttonClick"/></td>

单击此按钮时,我会检索被单击行的 ID,使用相同的 ID 设置会话并绑定网格 view.This 列表视图中单击按钮背后的代码:

ListViewItem item = (sender as Button).NamingContainer as ListViewItem;
    Button butDetails = (Button)item.FindControl("Button2");
    Int64 inquiryID = Convert.ToInt64(butDetails.CommandArgument);
    Session["session_view_id"] = inquiryID;
    this.BindGrid();               
    return;

会话在 bindGrid 函数中检索。但问题是 gridview 在第一次单击时不显示,但在第二次单击时显示,但使用前一个 id clicked.The 会话的数据设置,但在绑定网格时它使用旧会话值。我哪里错了绑定网格? bindGrid() 函数的代码是:

 int inquiryID = Convert.ToInt32(Session["session_view_id"]);
   MySqlConnection conn = null;
    try
    {          MySqlCommand cmd = new MySqlCommand("SELECT * FROM crm_support_inquiry inner join  crm_inquiry_perticipant on crm_support_inquiry.inquiry_id=?id inner join crm_mailer_types on crm_support_inquiry.mailer_id=crm_mailer_types.mailer_id limit 4", connect);

        using (MySqlDataAdapter sda = new MySqlDataAdapter())
        {
            cmd.Parameters.AddWithValue("?id", inquiryID);
            cmd.Connection = connect;
            sda.SelectCommand = cmd;
            using (DataTable dt = new DataTable())
           {

               sda.Fill(dt);
                lblComp.Text = dt.Rows[0]["company"].ToString();
                lblCname.Text = dt.Rows[0]["contact_name"].ToString();
              lblEmail.Text = dt.Rows[0]["email"].ToString();
                GridView1.DataSource = dt;
                GridView1.DataBind();
           }
        }

您是否在 Page_Load 方法中检查 IsPostBack?您需要在 if(!IsPostBack) 语句中将 Page_Load 中的 BindGrid 调用包装起来,以防止 Page_Load 在回发时最初刷新数据。这可以防止您稍后在事件处理程序中进行更改。

protected void Page_Load(Object sender, EventArgs e)
{
    if(!IsPostBack)
    {
        BindGrid();
    }
}

这个答案可以提供额外的信息:How to update page data after event handling?