尝试保存更改时,为什么GridView行的DataItem为null?

The*_*erm 10 asp.net gridview

所以我的网页上有这个GridView.它是数据绑定的,因此在RowDataBound事件期间,此代码运行良好:

    protected void myGridView_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            TimecardApproval shift = (TimecardApproval)e.Row.DataItem;
        }
    }
Run Code Online (Sandbox Code Playgroud)

"shift"变量包含我需要的所有数据,效果很好.但是,这是用于保存数据的代码:

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

DataItem为null!为什么?由于该字段存在,因此它似乎很奇怪.我应该循环其他东西吗?

cod*_*biz 12

我知道您可能希望通过将DataItem强制转换为TimeCardApproval来实现智能感知.你可以这样做.使用DataKeyNames存储每行的主键,应该TimecardApprovalID在您的代码中访问主键并使用它来获取原始项

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);

}
Run Code Online (Sandbox Code Playgroud)

设置密钥

<asp:GridView ID="gvTimeCards" DataKeyNames="TimecardApprovalID">
</asp:GridView>
Run Code Online (Sandbox Code Playgroud)

  • 什么是***表现***?访问每行的DB(使用ID)?30行,30次调用DB? (2认同)