一、对于GridView控件中的<asp:BoundField>字段,如果在RowDataBound事件中改变它的值,点击Edit按钮时,该字段将不再进入编辑状态。例:
1、html代码
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"
Width="650px" OnRowDeleting="GridView1_RowDeleting" AllowPaging="True" CellPadding="4" ForeColor="#333333" GridLines="None" OnRowDataBound="GridView1_RowDataBound" OnRowEditing="GridView1_RowEditing" Font-Size="10pt" DataSourceID="SqlDataSource1" OnRowUpdating="GridView1_RowUpdating" DataKeyNames="examid">
<Columns>
<asp:TemplateField HeaderText="专业名称">
<EditItemTemplate>
<asp:DropDownList ID="DdlPro" runat="server">
</asp:DropDownList>
</EditItemTemplate>
<ItemTemplate>
<asp:Label ID="LbPro" runat="server" Text='<%# Eval("professionname") %>'></asp:Label>
</ItemTemplate>
<ItemStyle Width="12%" />
</asp:TemplateField>
<asp:BoundField DataField="addtime" DataFormatString="{0:d}" HeaderText="加入时间" />
<asp:CommandField HeaderText="编辑" ShowEditButton="True">
</asp:CommandField>
</Columns>
</asp:GridView>
2、C#代码
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
if (e.Row.RowState == DataControlRowState.Edit || (e.Row.RowState== (DataControlRowState.Edit | DataControlRowState.Alternate)))
{
e.Row.Cells[1].Text=Convert.ToDateTime(((TextBox)e.Row.Cells[1].Controls[0]).Text.Trim()).ToString();
}
e.Row.Cells[1].Text = Convert.ToDateTime(e.Row.Cells[1].Text).ToShortDateString();
}
}
二、GridView控件的RowEditing、RowUpdating事件用Return语句无法阻止其进入编辑状态和进行数据更新。
1、在RowEditing中使用Return语句,其作用只是跳过RowEditing事件中Return语句后面的代码,并不影响进入编辑状态。即一旦进入RowEditing事件,进入编辑状态便不可避免。
2、在RowUpdating事件使用Return语句,其作用只是跳过RowUpdating事件中Return语句后面的代码,数据更新会继续进行,即程序仍然要执行数据更新的操作。即一旦进入RowUpdating事件,数据更新操作便不可中止。
三、使用GridView控件时必须设置DataKeyNames属性
四、可使用GridView的DataBind()方法重新绑定更新后的数据(一般用于数据源改变或更新后)。例:GridView1.DataBind();
五、如果GridView控件的<asp:BoundField>字段的ReadOnly属性设置为True,执行GridView控件的RowUpdating事件进行数据更新后,将会把Null赋予ReadOnly属性设置为True的<asp:BoundField>字段,从而造成数据的丢失。