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

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

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

  1. protected void btnSubmitApprovals_Click(object sender,ImageClickEventArgs e)
  2. {
  3. foreach (GridViewRow item in gvTimeCards.Rows)
  4. {
  5. TimecardApproval shift = (TimecardApproval)item.DataItem;
  6. // code to update the row
  7. }
  8. }

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

解决方法

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

设置键

  1. <asp:GridView ID="gvTimeCards" DataKeyNames="TimecardApprovalID">
  2. </asp:GridView>

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