Occurs when a row's Edit button is clicked, but before the GridView control enters edit mode.
Assembly: System.Web (in System.Web.dll)
Public Event RowEditing As GridViewEditEventHandler
public event GridViewEditEventHandler RowEditing
public: event GridViewEditEventHandler^ RowEditing { void add (GridViewEditEventHandler^ value); void remove (GridViewEditEventHandler^ value); }
member RowEditing : IEvent<GridViewEditEventHandler,
GridViewEditEventArgs>
<asp:GridView OnRowEditing="GridViewEditEventHandler" />
The RowEditing event is raised when a row's Edit button is clicked, but before the GridView control enters edit mode. This enables you to provide an event-handling method that performs a custom routine, such as canceling the edit operation, whenever this event occurs.
A GridViewEditEventArgs object is passed to the event-handling method, which enables you to determine the index of the current row and to indicate that the edit operation should be canceled. To cancel the edit operation, set the Cancel property of the GridViewEditEventArgs object to true.
For more information about handling events, see Consuming Events.
The following example demonstrates how to use the RowEditing event to put a row in edit mode when the data source is set programmatically.
<%@ Page Language="VB" %> <%@ Import Namespace="System.Data" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <script runat="server"> Protected Sub Page_Load() If Not Page.IsPostBack Then ' Create a new table. Dim taskTable As New DataTable("TaskList") ' Create the columns. taskTable.Columns.Add("Id", GetType(Integer)) taskTable.Columns.Add("Description", GetType(String)) taskTable.Columns.Add("IsComplete", GetType(Boolean)) 'Add data to the new table. For i = 0 To 19 Dim tableRow = taskTable.NewRow() tableRow("Id") = i tableRow("Description") = "Task " + i.ToString() tableRow("IsComplete") = False taskTable.Rows.Add(tableRow) Next 'Persist the table in the Session object. Session("TaskTable") = taskTable 'Bind data to the GridView control. BindData() End If End Sub Protected Sub TaskGridView_PageIndexChanging(ByVal sender As Object, ByVal e As GridViewPageEventArgs) TaskGridView.PageIndex = e.NewPageIndex 'Bind data to the GridView control. BindData() End Sub Protected Sub TaskGridView_RowEditing(ByVal sender As Object, ByVal e As GridViewEditEventArgs) 'Set the edit index. TaskGridView.EditIndex = e.NewEditIndex 'Bind data to the GridView control. BindData() End Sub Protected Sub TaskGridView_RowCancelingEdit() 'Reset the edit index. TaskGridView.EditIndex = -1 'Bind data to the GridView control. BindData() End Sub Protected Sub TaskGridView_RowUpdating(ByVal sender As Object, ByVal e As GridViewUpdateEventArgs) 'Retrieve the table from the session object. Dim dt = CType(Session("TaskTable"), DataTable) 'Update the values. Dim row = TaskGridView.Rows(e.RowIndex) dt.Rows(row.DataItemIndex)("Id") = (CType((row.Cells(1).Controls(0)), TextBox)).Text dt.Rows(row.DataItemIndex)("Description") = (CType((row.Cells(2).Controls(0)), TextBox)).Text dt.Rows(row.DataItemIndex)("IsComplete") = (CType((row.Cells(3).Controls(0)), CheckBox)).Checked 'Reset the edit index. TaskGridView.EditIndex = -1 'Bind data to the GridView control. BindData() End Sub Private Sub BindData() TaskGridView.DataSource = Session("TaskTable") TaskGridView.DataBind() End Sub </script> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title>GridView example</title> </head> <body> <form id="form1" runat="server"> <div> <asp:GridView ID="TaskGridView" runat="server" AutoGenerateEditButton="True" AllowPaging="true" OnRowEditing="TaskGridView_RowEditing" OnRowCancelingEdit="TaskGridView_RowCancelingEdit" OnRowUpdating="TaskGridView_RowUpdating" OnPageIndexChanging="TaskGridView_PageIndexChanging"> </asp:GridView> </div> </form> </body> </html>
<%@ Page Language="C#" %> <%@ Import Namespace="System.Data" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <script runat="server"> protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { // Create a new table. DataTable taskTable = new DataTable("TaskList"); // Create the columns. taskTable.Columns.Add("Id", typeof(int)); taskTable.Columns.Add("Description", typeof(string)); taskTable.Columns.Add("IsComplete", typeof(bool) ); //Add data to the new table. for (int i = 0; i < 20; i++) { DataRow tableRow = taskTable.NewRow(); tableRow["Id"] = i; tableRow["Description"] = "Task " + i.ToString(); tableRow["IsComplete"] = false; taskTable.Rows.Add(tableRow); } //Persist the table in the Session object. Session["TaskTable"] = taskTable; //Bind data to the GridView control. BindData(); } } protected void TaskGridView_PageIndexChanging(object sender, GridViewPageEventArgs e) { TaskGridView.PageIndex = e.NewPageIndex; //Bind data to the GridView control. BindData(); } protected void TaskGridView_RowEditing(object sender, GridViewEditEventArgs e) { //Set the edit index. TaskGridView.EditIndex = e.NewEditIndex; //Bind data to the GridView control. BindData(); } protected void TaskGridView_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e) { //Reset the edit index. TaskGridView.EditIndex = -1; //Bind data to the GridView control. BindData(); } protected void TaskGridView_RowUpdating(object sender, GridViewUpdateEventArgs e) { //Retrieve the table from the session object. DataTable dt = (DataTable)Session["TaskTable"]; //Update the values. GridViewRow row = TaskGridView.Rows[e.RowIndex]; dt.Rows[row.DataItemIndex]["Id"] = ((TextBox)(row.Cells[1].Controls[0])).Text; dt.Rows[row.DataItemIndex]["Description"] = ((TextBox)(row.Cells[2].Controls[0])).Text; dt.Rows[row.DataItemIndex]["IsComplete"] = ((CheckBox)(row.Cells[3].Controls[0])).Checked; //Reset the edit index. TaskGridView.EditIndex = -1; //Bind data to the GridView control. BindData(); } private void BindData() { TaskGridView.DataSource = Session["TaskTable"]; TaskGridView.DataBind(); } </script> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title>GridView example</title> </head> <body> <form id="form1" runat="server"> <div> <asp:GridView ID="TaskGridView" runat="server" AutoGenerateEditButton="True" AllowPaging="true" OnRowEditing="TaskGridView_RowEditing" OnRowCancelingEdit="TaskGridView_RowCancelingEdit" OnRowUpdating="TaskGridView_RowUpdating" OnPageIndexChanging="TaskGridView_PageIndexChanging"> </asp:GridView> </div> </form> </body> </html>
The following example demonstrates how to use the RowEditing event to cancel the editing operation if the user attempts to edit the record for a company in the United States.
<%@ Page language="VB" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <script runat="server"> Sub CustomersGridView_RowEditing(ByVal sender As Object, ByVal e As GridViewEditEventArgs) ' Get the country for the row being edited. For this example, the ' country is contained in the seventh column (index 6). Dim country As String = CustomersGridView.Rows(e.NewEditIndex).Cells(6).Text ' For this example, cancel the edit operation if the user attempts ' to edit the record of a customer from the United States. If country = "USA" Then ' Cancel the edit operation. e.Cancel = True Message.Text = "You cannot edit this record." Else Message.Text = "" End If End Sub </script> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>GridView RowEditing Example</title> </head> <body> <form id="form1" runat="server"> <h3>GridView RowEditing Example</h3> <asp:label id="Message" forecolor="Red" runat="server"/> <br/> <!-- The GridView control automatically sets the columns --> <!-- specified in the datakeynames property as read-only. --> <!-- No input controls are rendered for these columns in --> <!-- edit mode. --> <asp:gridview id="CustomersGridView" datasourceid="CustomersSqlDataSource" autogeneratecolumns="true" autogenerateeditbutton="true" allowpaging="true" datakeynames="CustomerID" onrowediting="CustomersGridView_RowEditing" runat="server"> </asp:gridview> <!-- This example uses Microsoft SQL Server and connects --> <!-- to the Northwind sample database. Use an ASP.NET --> <!-- expression to retrieve the connection string value --> <!-- from the Web.config file. --> <asp:sqldatasource id="CustomersSqlDataSource" selectcommand="Select [CustomerID], [CompanyName], [Address], [City], [PostalCode], [Country] From [Customers]" updatecommand="Update Customers SET CompanyName=@CompanyName, Address=@Address, City=@City, PostalCode=@PostalCode, Country=@Country WHERE (CustomerID = @CustomerID)" connectionstring="<%$ ConnectionStrings:NorthWindConnectionString%>" runat="server"> </asp:sqldatasource> </form> </body> </html>
<%@ Page language="C#" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <script runat="server"> void CustomersGridView_RowEditing(Object sender, GridViewEditEventArgs e) { // Get the country for the row being edited. For this example, the // country is contained in the seventh column (index 6). String country = CustomersGridView.Rows[e.NewEditIndex].Cells[6].Text; // For this example, cancel the edit operation if the user attempts // to edit the record of a customer from the Unites States. if (country == "USA") { // Cancel the edit operation. e.Cancel = true; Message.Text = "You cannot edit this record."; } else { Message.Text = ""; } } </script> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>GridView RowEditing Example</title> </head> <body> <form id="form1" runat="server"> <h3>GridView RowEditing Example</h3> <asp:label id="Message" forecolor="Red" runat="server"/> <br/> <!-- The GridView control automatically sets the columns --> <!-- specified in the datakeynames property as read-only. --> <!-- No input controls are rendered for these columns in --> <!-- edit mode. --> <asp:gridview id="CustomersGridView" datasourceid="CustomersSqlDataSource" autogeneratecolumns="true" autogenerateeditbutton="true" allowpaging="true" datakeynames="CustomerID" onrowediting="CustomersGridView_RowEditing" runat="server"> </asp:gridview> <!-- This example uses Microsoft SQL Server and connects --> <!-- to the Northwind sample database. Use an ASP.NET --> <!-- expression to retrieve the connection string value --> <!-- from the Web.config file. --> <asp:sqldatasource id="CustomersSqlDataSource" selectcommand="Select [CustomerID], [CompanyName], [Address], [City], [PostalCode], [Country] From [Customers]" updatecommand="Update Customers SET CompanyName=@CompanyName, Address=@Address, City=@City, PostalCode=@PostalCode, Country=@Country WHERE (CustomerID = @CustomerID)" connectionstring="<%$ ConnectionStrings:NorthWindConnectionString%>" runat="server"> </asp:sqldatasource> </form> </body> </html>
.NET Framework
Supported in: 4, 3.5, 3.0, 2.0Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2
The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.
Reference
Other Resources
|
Date |
History |
Reason |
|---|---|---|
|
|
Made changes to the first example. |
Customer feedback. |
From this version on the EditIndex property is set by the framework even if the GridView is not bound using DataSourceID. This means that if you are upgrading from earlier versions of ASP.NET you could see a change in behaviour (gridviews going into to edit mode - showing textboxes)
For more information:
https://connect.microsoft.com/VisualStudio/feedback/details/554166/gridview-sets-editindex-property-when-in-previous-net-versions-it-didnt
If you are upgrading from a previous asp.net version and don't want this behaviour you can add the following code to your RowEditing event
e.Cancel = true;
Protected Sub gvsubAccounts_RowUpdating(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewUpdateEventArgs) Handles gvsubAccounts.RowUpdating
'Retrieve the table from the session object.
Dim dt = CType(Session("Table"), DataTable)
'Update the values.
Dim row = gvsubAccounts.Rows(e.RowIndex)
' I have a delete button and an edit button at the beginning so the actual data starts at cell 2
For i As Integer = 0 To row.Cells.Count - 3
dt.Rows(row.DataItemIndex)(i) = (CType((row.Cells(i + 2).Controls(0)), TextBox)).Text
Next
Session("table") = dt
'Reset the edit index.
gvsubAccounts.EditIndex = -1
'Bind data to the GridView control.
BindData()
End Sub
[Tom Dykstra - MSFT] Actually the page does work correctly as-is (updates are reflected in the grid) because the variable dt is a reference to the session object.
Occurs when a row's Edit button is clicked, but before the GridView control enters edit mode.
The fact is that the GridView IS already in edit mode, by the time you attempt to retrieve a value from the grid. Steps to follow in duplicating the issue:
1. create a GridView control and populate two or more rows of data, using labels to hold the numeric value you want to later retrieve (in my case, "downtime hours")
2. set a breakpoint in the RowEditing event and loop through the rows and attempt to retrieve the value of the control previously populated with data (in my case, row 0 has a value of 4D)
3. here's my partial code:
protected void downtimeGrid_RowEditing(object sender, GridViewEditEventArgs e)
{
double downtimeHours = 0D;
foreach (GridViewRow row in downtimeGrid.Rows)
{
if (row.RowIndex != e.NewEditIndex)
{
downtimeHours += double.Parse(((Label)row.FindControl("downtimeHoursLabel")).Text);
}
}
When run, this code produces an error, stating that the input string is not in the correct format. From the Immediate Window:
?(Label)row.FindControl("downtimeHoursLabel")
{Text = ""}
base {System.Web.UI.WebControls.WebControl}: {Text = ""}
_textSetByAddParsedSubObject: false
AssociatedControlID: ""
AssociatedControlInControlTree: true
RequiresLegacyRendering: true
SupportsDisabledAttribute: false
TagKey: Span
Text: ""
As you can see, the value is lost, because the GridView has already switched to EditTemplate mode (and the value of 4 only exists in the ItemTemplate mode).