DropDownList.SelectedValue无效

时间:2019-05-05 19:58:45

标签: c# asp.net .net dropdown selectedvalue

这似乎是一个重复的问题,但我认为不是。我要在ASPX页中设置asp:DropDownList,并在SelectedValue事件期间将其设置为RowDataBound,然后检查当前的gridview行是否正在被编辑。设置控件的SelectedValue属性时,并在设置后立即对其进行检查时,都不会引发任何错误。

这是相关代码

            <asp:SqlDataSource
                ID="DataSourceAnswerGroups"
                runat="server"
                ConnectionString="<%$ ConnectionStrings %>"
                DataSourceMode="DataSet"
                SelectCommand="
                    SELECT
                        Id
                       ,Description
                    FROM dbo.table
                    WHERE Active = 1
                    ORDER BY Description
                    ;
                " />
            <asp:GridView
                ID="GridView"
                runat="server"
                OnRowDataBound="GridView_RowDataBound">
                <Columns>
                    <asp:TemplateField HeaderText="Answer Group" SortExpression="AnswerGroup" ItemStyle-Wrap="false" ItemStyle-CssClass="left">
                        <ItemTemplate>
                            <%# Eval("AnswerGroup") %>
                        </ItemTemplate>
                        <EditItemTemplate>
                            <asp:DropDownList
                                ID="ddlAnswerGroupEdit"
                                runat="server"
                                DataSourceID="DataSourceAnswerGroups"
                                DataValueField="Id"
                                DataTextField="Description"/>
                        </EditItemTemplate>
                    </asp:TemplateField>
                </Columns>
            </asp:GridView>

后面的代码

    protected void GridView_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow && e.Row.RowIndex == GridView.EditIndex)
        {
            DropDownList ddlAnswerGroupEdit = (DropDownList)e.Row.FindControl("ddlAnswerGroupEdit");
            ddlAnswerGroupEdit.SelectedValue = GridView.DataKeys[e.Row.RowIndex].Values["AnswerGroupId"].ToString();
            Response.Write(GridView.DataKeys[e.Row.RowIndex].Values["AnswerGroupId"].ToString() + "<br/>"); // this outputs the correct guid
            Response.Write(ddlAnswerGroupEdit.SelectedValue + "<br/>"); // this always outputs the same guid, the one that represents the first item on the list.
        }
    }

在代码中的任何地方都没有对DdataSource或DropDownList的其他操作。 默认选择应该正在更改,但是它默默地失败了。 任何帮助将不胜感激。

2 个答案:

答案 0 :(得分:0)

您在哪里绑定AnswerGroupId?

替换

ddlAnswerGroupEdit.SelectedValue = GridView.DataKeys[e.Row.RowIndex].Values["AnswerGroupId"].ToString();

ddlAnswerGroupEdit.SelectedValue = GridView.DataKeys[e.Row.RowIndex]["AnswerGroupId"].ToString();

答案 1 :(得分:0)

要解决的所有愚蠢问题。这并不能解决问题,但确实使我朝着正确的方向前进。这是一个区分大小写的问题。 SQL Server以大写形式返回GUIID,而控制项以小写形式返回。这是我必须要做的唯一修复:

ddlAnswerGroupEdit.SelectedValue = GridView.DataKeys[e.Row.RowIndex].Values["AnswerGroupId"].ToString().ToLower();