asp.net – 为什么当试图保存更改时,GridView行“null”的DataItem为null?

前端之家收集整理的这篇文章主要介绍了asp.net – 为什么当试图保存更改时,GridView行“null”的DataItem为null?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
所以我在我的网页上有这个GridView.它是数据绑定的,所以在RowDataBound事件期间,这段代码工作得很好: @H_403_2@protected void myGridView_RowDataBound(object sender,GridViewRowEventArgs e) { if (e.Row.RowType == DataControlRowType.DataRow) { TimecardApproval shift = (TimecardApproval)e.Row.DataItem; } }

“shift”变量具有我需要的所有数据,效果很好.但是,存在用于保存数据的代码

@H_403_2@protected void btnSubmitApprovals_Click(object sender,ImageClickEventArgs e) { foreach (GridViewRow item in gvTimeCards.Rows) { TimecardApproval shift = (TimecardApproval)item.DataItem; // code to update the row } }

DataItem为空!为什么?由于该领域在那里,看起来很奇怪,它是空的.我应该循环些别的东西吗?

解决方法

我明白你可能希望通过将DataItem转换为TimeCardApproval来进行智能感知.你可以这样做.使用DataKeyNames存储每一行​​的主键,它们应该是TimecardApprovalID,并且在代码中访问主键,并使用它来获取原始项 @H_403_2@foreach (GridViewRow item in gvTimeCards.Rows) { //get the ID of the TimeApproval for each row string id = gvDocs.DataKeys[item.RowIndex].Value.ToString(); //string id = ((HiddenField) item.FindControl("IDHiddenField")).Value; //string id = item.Cells[0].Text; //use the ID or get TimeCardApproval object from DB TimecardApproval shift = MyDB.GetTimeCardApproval(id); }

设置键

@H_403_2@<asp:GridView ID="gvTimeCards" DataKeyNames="TimecardApprovalID"> </asp:GridView>

猜你在找的asp.Net相关文章