3

我在 gridview 上应用编辑功能。

当我的代码控件处于 rowupdating 事件中时,我发现我正在从文本框中获取先前的值(即在我在文本框中进行编辑之前的值)。

以下是我的代码:

Protected Sub gvBooking_RowUpdating(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewUpdateEventArgs) Handles gvBooking.RowUpdating
            'Dim name As String = DirectCast(gvBooking.Rows(e.RowIndex).FindControl("txtperson1"), TextBox).Text
            Dim nname As String = (gvBooking.DataKeys(e.RowIndex).Values("person_name").ToString)
            Dim id As Integer = Integer.Parse(gvBooking.DataKeys(e.RowIndex).Value.ToString)
            Dim carname As String = gvBooking.DataKeys(e.RowIndex).Values("car_name").ToString

            Dim carac As String = ""


            'Dim sql As String = ""
            'sql = "update dbo.tbl_Book set person_name='" + name + "',ac_type='" + carac + "' where booking_id = " + id.ToString
            'gc.ExecuteCommand(sql)
            'gvBooking.EditIndex = -1
            'gc.BindGridView(gvBooking, "select * from tbl_Book")
        End Sub

在此,如果我将人名从 Henry 编辑为 Scott,然后按更新按钮,那么我通过调试器发现 nname 的值仅为 Henry,这是我进行编辑之前的值,而不是它应该具有我编辑的值 Scott .

我不明白我在哪里犯错。

请帮我。

4

1 回答 1

2

单击更新后,将引发两个事件。

1.) GridView.Updating :在更新即将提交之前引发。在这种情况下,数据库中的数据仍未更新。基本上,此事件用于在 Update 方法实际将更改的数据提交到数据库之前应用一些动态更改。

2.) GridView.Updated 此事件在数据更新后立即引发。因此,只有在这种情况下,您才放置一个调试符号并检查值。你会看到你的新价值:Scott。

 <asp:GridView ID="GridView1" runat="server" OnRowUpdated="GridView1_RowUpdated"></asp:GridView>    

当您在未进行更新时检查数据时。这就是您仅获取原始值的原因。在 GridView1_RowUpdated() 方法中只检查新值。

此外,如果您想在更新事件中检查您的新值,请使用 GridViewUpdateEventArgs.NewValues属性[e.Newvalues] 作为:[在此处查看MSDN ]

  string s = e.NewValues[1].ToString(); // 2nd Column // c# sample 
于 2013-07-18T05:27:55.863 回答