C# 在c中以gridview编辑模式填充dropdownlist时出现问题

C# 在c中以gridview编辑模式填充dropdownlist时出现问题,c#,asp.net,c#-4.0,gridview,drop-down-menu,C#,Asp.net,C# 4.0,Gridview,Drop Down Menu,我有一个可编辑的Gridview,列名为Country,它的列表很长 当我显示数据时,国家/地区的值在标签中,但当我选择“编辑”时,应显示带有国家/地区列表的下拉列表。我能够显示列表。它应显示所选的国家,如标签中所示 我已经尝试过了,但是dropdownlist中填充了System.Row.DataRowView,而且它没有设置为SelectedValue作为cvalue给定 aspx页 <asp:TemplateField HeaderText="Country">

我有一个可编辑的Gridview,列名为Country,它的列表很长

当我显示数据时,国家/地区的值在标签中,但当我选择“编辑”时,应显示带有国家/地区列表的下拉列表。我能够显示列表。它应显示所选的国家,如标签中所示

我已经尝试过了,但是dropdownlist中填充了System.Row.DataRowView,而且它没有设置为SelectedValue作为cvalue给定

aspx页

<asp:TemplateField HeaderText="Country">
                            <ItemTemplate>
                                <asp:Label ID="lblCountry" runat="server" Text='<%#Bind("Country")%>'></asp:Label>
                            </ItemTemplate>
                            <EditItemTemplate>
                                <asp:DropDownList ID="ddlCCountry" runat="server" Height="21px" Style="margin-left: 0px"
                                    Width="194px">
                                    <asp:ListItem Value="-1">Select..</asp:ListItem>
                                    <asp:ListItem Value="af">Afghanistan</asp:ListItem>
                                    <asp:ListItem Value="ax">Aland Islands</asp:ListItem>
                                    <asp:ListItem Value="al">Albania</asp:ListItem>
                                 </asp:DropDownList>
                              <EditItemTemplate>  

有什么问题吗?

这对我很有效。填充GridView时,应填充RowDataBound事件中的每个DropDownList:

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
    numberFormatDA formatDA = new numberFormatDA();

    DataTable mytable = new DataTable();
    DataColumn formatIDcolumn = new DataColumn("fkNumberFormat");
    DataColumn formatNameColumn = new DataColumn("numberFormat");

    mytable.Columns.Add(formatIDcolumn);
    mytable.Columns.Add(formatNameColumn);

    DataSet ds = new DataSet();
    ds = formatDA.getNumberFormatsDS();

    if ((e.Row.RowState & DataControlRowState.Edit) > 0)
    {
        TextBox txtSite = (TextBox)e.Row.FindControl("txtIDSite");

        DropDownList ddl = (DropDownList)e.Row.FindControl("ddlNumberFormat");
        DataRow[] rows = ds.Tables[0].Select();

        foreach (DataRow row in rows)
        {
            DataRow newrow = mytable.NewRow();
            newrow["fkNumberFormat"] = row["idnumberFormat"];
            newrow["numberFormat"] = row["numberFormat"];
            mytable.Rows.Add(newrow);
        }

        ddl.DataSource = mytable;
        ddl.DataTextField = "numberFormat";
        ddl.DataValueField = "fkNumberFormat";

        int numberFormatID = 0;
        Label lblFormatID = (Label)e.Row.FindControl("numberFormatLabel");
        numberFormatID = Int32.Parse(lblFormatID.Text);

        ddl.SelectedValue = numberFormatID.ToString();
        ddl.DataBind();
    }
}

希望这有帮助

这样你可以让它工作,但我知道有更好的方法来实现这一点。。 现在试试这个

protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)
    {
        GridViewRow gvr = GridView1.Rows[e.NewEditIndex];
        Label lb = (Label)gvr.FindControl("lblCountry");

        GridView1.EditIndex = e.NewEditIndex;
        binddata();
        getselected(lb.Text);
    }


    private void getselected(string text)
    {
        GridViewRow gvr = GridView1.Rows[GridView1.EditIndex];

        DropDownList dr = (DropDownList)gvr.FindControl("ddlCCountry");
        dr.SelectedIndex = dr.Items.IndexOf(dr.Items.FindByText(text));

    }

现在回答这个问题已经太迟了,但希望它能帮助别人。您可以将SelectedValue属性放置在dropdownlist标记中,如下所示:

 <asp:DropDownList SelectedValue='<% Eval("Country") %>' ID="ddlCCountry" runat="server" Height="21px" Style="margin-left: 0px" Width="194px">
   <asp:ListItem Value="-1">Select..</asp:ListItem>
   <asp:ListItem Value="af">Afghanistan</asp:ListItem>
   <asp:ListItem Value="ax">Aland Islands</asp:ListItem>
   <asp:ListItem Value="al">Albania</asp:ListItem>
 </asp:DropDownList>

我需要在编辑模式下从标签中获取值,并设置标签值的gridview的selectedItem,这正是这段代码应该做的。您需要根据需要更改课程。但这是应该遵循的逻辑
protected void gvGeneralMaster_RowEditing(object sender, GridViewEditEventArgs e)
    {
        try
        {
            if (clsGeneral._strRights[2] == "0")
            {
                //ScriptManager.RegisterClientScriptBlock(this.Page, this.GetType(), "ShowAlert", "ShowAlert();", true);               
                //ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "ShowUnAuthorisedMsg", "ShowUnAuthorisedMsg();", true);
                Response.Redirect("UnauthorizedUser.aspx");
            }
            else
            {
                GridViewRow gvRow = (GridViewRow)gvGeneralMaster.Rows[e.NewEditIndex];
                ViewState["COUNTRY"] = ((Label)gvRow.FindControl("lblCountry")).Text.Trim();
                ViewState["STATE"] = ((Label)gvRow.FindControl("lblState")).Text.Trim();

                gvGeneralMaster.EditIndex = e.NewEditIndex;
                GetGeneralDetails();
            }
        }
        catch (Exception ex)
        {
            lblErrorMsg.Text = ex.Message.ToString();
            if (!ex.Message.ToString().Contains("Thread was being aborted."))
            {
                //oBL_ClsLog.SaveLog(Convert.ToString(Session["CurrentUser"]).Trim(), "Exception", ex.Message.ToString(), "GROUP MASTER");
                ErrMsg = ex.Message.ToString(); try { string[] arrErr = ex.Message.ToString().Split('\n'); ErrMsg = arrErr[0].ToString().Trim(); }
                catch { } Response.Redirect("Error.aspx?Error=" + ErrMsg.ToString().Trim());
            }
        }
    }

    protected void gvGeneralMaster_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        try
        {
            if (clsGeneral._strRights[2] == "0")
            {
                //ScriptManager.RegisterClientScriptBlock(this.Page, this.GetType(), "ShowAlert", "ShowAlert();", true);               
                //ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "ShowUnAuthorisedMsg", "ShowUnAuthorisedMsg();", true);
                Response.Redirect("UnauthorizedUser.aspx");
            }
            else
            {
                GridViewRow gvRow = (GridViewRow)gvGeneralMaster.Rows[e.RowIndex];
                oPRP._GeneralCode = int.Parse(((Label)gvRow.FindControl("lblEGenCode")).Text.Trim());
                oPRP._GenaralName = ((TextBox)gvRow.FindControl("txtECity")).Text.Trim();
                oPRP._StateName = ((DropDownList)gvRow.FindControl("ddlEState")).SelectedItem.Text.Trim() != "SELECT" ? ((DropDownList)gvRow.FindControl("ddlEState")).SelectedItem.Text.Trim() : "";
                oPRP._CountryName = ((DropDownList)gvRow.FindControl("ddlECountry")).SelectedItem.Text.Trim() != "SELECT" ? ((DropDownList)gvRow.FindControl("ddlECountry")).SelectedItem.Text.Trim() : "";
                oPRP._Remarks = ((TextBox)gvRow.FindControl("txtERemarks")).Text.Trim();
                oPRP._Active = ((CheckBox)gvRow.FindControl("chkEditActive")).Checked;
                oPRP._ModifiedBy = Session["CurrentUser"].ToString();
                oDAL.SaveUpdateGeneralMaster("UPDATE", oPRP);

                gvGeneralMaster.EditIndex = -1;
                GetGeneralDetails();
            }
        }
        catch (Exception ex)
        {
            lblErrorMsg.Text = ex.Message.ToString();
            if (!ex.Message.ToString().Contains("Thread was being aborted."))
            {
                //oBL_ClsLog.SaveLog(Convert.ToString(Session["CurrentUser"]).Trim(), "Exception", ex.Message.ToString(), "GROUP MASTER");
                ErrMsg = ex.Message.ToString(); try { string[] arrErr = ex.Message.ToString().Split('\n'); ErrMsg = arrErr[0].ToString().Trim(); }
                catch { } Response.Redirect("Error.aspx?Error=" + ErrMsg.ToString().Trim());
            }
        }
    }
 <asp:DropDownList SelectedValue='<% Eval("Country") %>' ID="ddlCCountry" runat="server" Height="21px" Style="margin-left: 0px" Width="194px">
   <asp:ListItem Value="-1">Select..</asp:ListItem>
   <asp:ListItem Value="af">Afghanistan</asp:ListItem>
   <asp:ListItem Value="ax">Aland Islands</asp:ListItem>
   <asp:ListItem Value="al">Albania</asp:ListItem>
 </asp:DropDownList>