我在使用asp.net的GridView
时遇到了一个奇怪的问题。我有一个GridView
绑定到LinqDataSource
。在GridView
的行删除事件中,我从数据库中删除了该行,但是网格没有刷新(即使已经绑定到数据源)。
当我设置断点时,我可以看到OnRowDeleting
事件在LinqDS_Selecting
事件之后被触发。但在删除事件之后它并没有再次被触发!这可能是原因吗?我做错了什么?
请问有人能帮忙解决吗?非常感谢。
.aspx文件:
<asp:LinqDataSource
ID="LinqDS"
runat="server"
OnSelecting="LinqDS_Selecting">
</asp:LinqDataSource>
<asp:GridView
DataSourceID = "LinqDS"
ID = "gv1"
runat = "server"
DataKeyNames = "InstructionId"
EnableViewState = "false"
OnRowDataBound = "gv1_RowDataBound"
OnRowDeleting = "gv1_RowDeleting"
OnRowCommand = "gv1_RowCommand"
PageSize = "30" >
<Columns>
<!-- My colums --->
</Columns>
</asp:GridView>
.aspx.cs
protected void Page_Load(object sender, EventArgs e)
{
}
protected void LinqDS_Selecting(object sender, LinqDataSourceSelectEventArgs e)
{
// my linq to sql query
var query = from .... .... ;
e.Result = query;
}
protected void gv1_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
int instructionId = (int)gv1.DataKeys[e.RowIndex].Value;
/// my delete logic
CTX.SubmitChanges();
gv1.DataBind();
}
gv1_RowDeleting
是否已触发?如果是,您可能还需要执行LinqDS.DataBind()
吗? - Aristos