Как установить SelectedValue DropDownList в GridView EditTemplate - PullRequest
8 голосов
/ 13 августа 2010

Я пытаюсь сделать это , как и было сказано ранее.Единственное отличие, которое я обнаружил, - это дополнительный элемент списка, который был включен в код выше.

Я пытался использовать AppendDataBoundItems=true, но он все еще не работает.Я также хочу установить его значение по умолчанию равным значению, которое отображалось в метке itemtemplate, т.е. DropDownList's SelectedValue='<%# Eval("DepartmentName") %>', но это свойство недоступно для меня в выпадающем списке.Что может быть причиной.??

<EditItemTemplate>
    <asp:DropDownList ID="ddlDepartment_Edit" runat="server" 
        DataSourceID="dsDepartment_Edit" DataTextField="DepartmentName" 
        DataValueField="PK_DepartmentId">
    </asp:DropDownList>
    <asp:SqlDataSource ID="dsDepartment_Edit" runat="server" 
        ConnectionString="<%$ ConnectionStrings:BlackHillsConnect %>"  
        ProviderName="System.Data.SqlClient" SelectCommand="sp_GetDepartmentDropDown" 
        SelectCommandType="StoredProcedure">
    </asp:SqlDataSource>                                 
</EditItemTemplate>
<ItemTemplate>
    <asp:Label ID="lblDepartmentName" runat="server" Text='<%# Eval("DepartmentName") %>' >
    </asp:Label>
</ItemTemplate>   

Я использую GridView

Ответы [ 5 ]

8 голосов
/ 13 августа 2010

DataValueField кажется неправильным - не должно ли это быть DepartmentId? Точно так же вам нужно, чтобы SelectedValue='<%# Eval("**DepartmentId**") %>' - DepartmentName было бы SeletectText.

3 голосов
/ 27 февраля 2013

Использование обработчика событий GridView_DataBound решает проблему.

В вашем случае вам потребуется добавить HiddenField для хранения значения PK_DepartmentId:

<asp:GridView ID="gvExample" runat="server" AutoGenerateColumns="False" OnDataBound="gvExample_DataBound">
  <Columns>
    <asp:TemplateField HeaderText="Department">
      <EditItemTemplate>
        <asp:DropDownList ID="ddlDepartment_Edit" runat="server" DataSourceID="dsDepartment_Edit"
          DataTextField="DepartmentName" DataValueField="PK_DepartmentId">
        </asp:DropDownList>
        <asp:HiddenField ID="hfDepartmentId" runat="server" Value='<%# Bind("PK_DepartmentId") %>' />
        <asp:SqlDataSource ID="dsDepartment_Edit" runat="server" ConnectionString="<%$ ConnectionStrings:BlackHillsConnect %>"
          ProviderName="System.Data.SqlClient" SelectCommand="sp_GetDepartmentDropDown" SelectCommandType="StoredProcedure">
        </asp:SqlDataSource>
      </EditItemTemplate>
      <ItemTemplate>
        <asp:Label ID="lblDepartmentName" runat="server" Text='<%# Eval("DepartmentName") %>'>
        </asp:Label>
      </ItemTemplate>
    </asp:TemplateField>
    <asp:CommandField ShowEditButton="True" ButtonType="Button" />
  </Columns>
</asp:GridView>

protected void gvExample_DataBound(object sender, EventArgs e)
{
  foreach (GridViewRow gvRow in gvExample.Rows)
  {
    DropDownList ddlDepartment = gvRow.FindControl("ddlDepartment_Edit") as DropDownList;
    HiddenField hfDepartmentId = gvRow.FindControl("hfDepartmentId") as HiddenField;

    if (ddlDepartment != null && hfDepartmentId != null)
    {
      ddlDepartment.SelectedValue = hfDepartmentId.Value;
    }
  }
}
1 голос
/ 13 сентября 2017

Почему вы, ребята, предлагаете использовать циклы, когда есть метод GridView, специально созданный для изменения условия строки - RowDataBound()?

protected void MyGridView_RowDataBound(object sender, GridViewRowEventArgs e)
        {
            GridViewRow gvRow = (GridViewRow)e.Row;
            HiddenField hfAgentID = (HiddenField)gvRow.FindControl("hfAgentID");
            if (hfAgentID != null)
            {
                if (e.Row.RowType == DataControlRowType.DataRow)
                {
                    DropDownList ddlAgent = (DropDownList)gvRow.FindControl("ddlAgent");
                    ddlAgent.SelectedValue = hfAgentID.Value;
                }
            }
        }
0 голосов
/ 04 сентября 2014

Это лучшее, что я нашел ....

protected void GridView1_DataBound(object sender, EventArgs e)
{
    foreach (GridViewRow gvRow in GridView1.Rows)
    {
        RadioButtonList rbl = gvRow.FindControl("rblPromptType") as RadioButtonList;
        HiddenField hf = gvRow.FindControl("hidPromptType") as HiddenField;

        if (rbl != null && hf != null)
        {
            if (hf.Value != "")
            {
                //clear the default selection if there is one
                rbl.ClearSelection();
            }

            rbl.SelectedValue = hf.Value;
        }
    }
}
0 голосов
/ 13 августа 2010

В вашей сетке есть событие под названием ItemCommand. Создайте для него метод:

protected void Grid1_ItemCommand(object source, GridCommandEventArgs e)

Теперь просто создайте оператор case, который распознает, когда пользователь нажал кнопку редактирования в сетке:

 case Grid.EditCommandName:     
//set a member variable to the string of the cell you are editing.
//something like: mString = e.item..["Column"].toString();                  
                   break;

Теперь у вас есть переменная-член, установленная на строку, которую вы хотите выбрать до того, как выпадающий список будет загружен / предварительно отображен. Используйте событие OnPrerender или OnLoad для dropdownbox и установите для выбранного элемента эту строку.

...