C# 无法强制转换类型为';Obout.Grid.GridTemplate';输入';System.Web.UI.WebControls.GridViewRow';。不解决

C# 无法强制转换类型为';Obout.Grid.GridTemplate';输入';System.Web.UI.WebControls.GridViewRow';。不解决,c#,asp.net,gridview,obout,C#,Asp.net,Gridview,Obout,我想禁用gridview单击gridview中的按钮时的行。为此,我编写了以下代码 protected void btnPayGenInvoice_Click(object sender, EventArgs e) { if (strMode == "M") { Button btn = (Button)sender; GridViewRow row = (GridViewRow)btn.Parent.Parent; row.Ena

我想
禁用gridview
单击gridview中的按钮时的行。为此,我编写了以下代码

protected void btnPayGenInvoice_Click(object sender, EventArgs e)
{
    if (strMode == "M")
    {
        Button btn = (Button)sender;
        GridViewRow row = (GridViewRow)btn.Parent.Parent;
        row.Enabled = false;
    }
}
但我也有错误

无法将“Obout.Grid.GridTemplate”类型的对象强制转换为“System.Web.UI.WebControls.GridViewRow”类型

请告诉我这里出了什么问题

更新

在第
GridViewRow行=(GridViewRow)btn.Parent.Parent行获取错误

更新2

按钮单击事件的代码

protected void GetRowDataPay(object sender, CommandEventArgs e)
{
    int rowIndex = int.Parse(e.CommandArgument.ToString());

    Hashtable dataItemPay = GridPayInfo.Rows[rowIndex].ToHashtable() as Hashtable;

    if (ObjPriCon.State != ConnectionState.Open)
    {
        ObjPriCon.Open();
        OracleCommand cmdMkeyPay = new OracleCommand("select XXCUS.XXACL_LAND_PURC_INV_VIEW_MKEY.nextval from dual", ObjPriCon);
        string MkeyPay = Convert.ToString(cmdMkeyPay.ExecuteOracleScalar());

        OracleCommand cmdORGID = new OracleCommand("select XXCUS.XXACL_LAND_PURC_INV_VIEW_MKEY.nextval from dual", ObjPriCon);
        string ORG_IDKEY = CF.ExecuteScaler2("select ORGANIZATION_ID,ORGANIZATION_NAME from apps.xxacl_company_mst where ORGANIZATION_NAME = '" + txtCompName.Value + "'");

        string strExpQuery = "insert into XXCUS.XXACL_LAND_PURC_INVOICE_VIEW (MKEY,REF_PURCHASE_ID,REF_SR_NO, " +
                         "REF_PURHCASE_TYPE,ORG_ID,PROJECT_ID,TALUKA_ID,VILLAGE_ID,SURVEY_AREA_7_12,DOC_NO,INVOICE_ID,INVOICE_NUM,VENDOR_ID, " +
                         "VENDOR_NAME,INVOICE_AMT,BATCH_ID,BATCH_NAME,EXP_ID,EXP_TYPE,REMARKS,CREATED_BY, " +
                         "CREATION_DATE,LAST_UPDATE_DATE,LAST_UPDATED_BY, EXP_ORG_ID, EXP_ORG_NAME) values (" + MkeyPay + "," + StrMkey + "," +
                         "" + dataItemPay["SR_NO"] + ", '" + dataItemPay["ATTRIBUTE1"] + "'," + ORG_IDKEY + "," + ddlProject.SelectedValue + "," +
                         "" + ddlTaluka.SelectedValue + "," + ddlVillage.SelectedValue + ", '" + txt712.Text + "', '" + txtdocno.Value + "'," + "NULL" + "," + "NULL" + "," +
                         "" + dataItemPay["ORACLE_VENDOR_ID"] + ", '" + dataItemPay["ORACLE_VEND_NAME"] + "', " + dataItemPay["PAID_AMT"] + "," + dataItemPay["BATCH_ID"] + "," +
                         "'" + dataItemPay["BATCH_NAME"] + "', " + dataItemPay["EXP_ID"] + ", '" + dataItemPay["EXP_TYPE"] + "', '" + dataItemPay["REMARKS"] + "', " +
                         "" + Request.QueryString["userid"].ToString() + ", sysdate, sysdate, " +
                         "'" + Request.QueryString["userid"].ToString() + "', " + "NULL" + "," + "NULL" + ")";
        OracleCommand cmdQuery = new OracleCommand(strExpQuery, ObjPriCon);
        cmdQuery.ExecuteNonQuery();
        ObjPriCon.Close();
        ScriptManager.RegisterStartupScript(this, this.GetType(), "Success", "alert('Payment Invoice inserted into table successfully');", true);
    }
}

您应该使用rowIndex值来获取gridviewrow,然后像这样禁用它

if (GridPayInfo.Rows[rowIndex] != null) 
{ 
  GridPayInfo.Rows[rowIndex].Enabled = false; 
}

要禁用的行。Yiu需要获取要禁用的选定行并将其传递给代码。然后您可以禁用该行。@YashveerSingh:是的,我想禁用单击按钮的行。确定,因此您必须有一个选定的行事件,当您在该事件上选择该记录时,该事件将被激发。您可以执行此操作。我将更新问题中的事件代码。请让我知道如何获取所选行并禁用它。好的,我将尝试我的最佳保护void btnpaygenvoice_Click(对象发送者,事件参数e){if(GridPayInfo.Rows[rowIndex]!=null){if(strMode==“M”){Button btn=(Button)发送者;GridViewRow.Rows[rowIndex].Enabled=false;}}谢谢Yashvier,这一个非常好用。。!!需要知道如何禁用删除部分。我有很多其他问题,稍后将发布并让你知道。现在谢谢你。。祝你有个愉快的一天嗨@nad没有问题请让我知道我会尽力回答的问题answer@nad是的,请告诉我