Como obter o valor de datafieldtext ou SelectedText do SelectList no MVC asp.net?

votos
0

No javascript \ AJAX é para ser usado.

Publicado 27/08/2009 em 03:34
fonte usuário
Em outras línguas...                            


3 respostas

votos
2

A classe abaixo usa a reflexão para obter o texto para o valor selecionado na lista. Vários itens da lista de selecionados não são suportados.

using System.Web.Mvc;

/// <summary>
/// Provides a set of static methods for getting the text for the selected value within the list.
/// </summary>
public static class SelectListExtensions
{
    /// <summary>
    /// Gets the text for the selected value.
    /// </summary>
    /// <param name="list">The list.</param>
    /// <returns></returns>
    public static string GetSelectedText(this SelectList list)
    {
        foreach(var item in list.Items)
        {
            var dataValuePropertyInfo = item.GetType().GetProperty(list.DataValueField);
            var itemValue = dataValuePropertyInfo.GetValue(item, null);

            if(itemValue != null && itemValue.Equals(list.SelectedValue))
            {
                var textValuePropertyInfo = item.GetType().GetProperty(list.DataTextField);
                return textValuePropertyInfo.GetValue(item, null) as string;
            }
        }

        return null;
    }
}
Respondeu 20/04/2010 em 13:09
fonte usuário

votos
0

Certo, se você construir a lista em código por trás e você dar a cada opção de um identificador único, então você pode pegar esse identificador e casar-se com um item no código e, portanto, o texto.

Assim;

public class MonthlyItemsFormViewModel
{
  public SelectList Months;
  public string SelectedMonth {get;set;}
}

então;

public ActionResult Index()
{
  MonthlyItemsFormViewModel fvm = new MonthlyItemsFormViewModel();
  FillData(fvm, DateTime.Now);
  return View(fvm);
}

E depois;

private void FillData(MonthlyItemsFormViewModel fvm, DateTime SelectedMonth)
{
  List<string> months = DateTime.Now.MonthList(DateTime.Now);
  fvm.Months = new SelectList(months, fvm.SelectedMonth);
}

Então, na sua opinião;

<% using (Html.BeginForm()) { %>
  <%=Html.DropDownList("selectedMonth", Model.Months) %>
<%} %>

Em seguida, no posto de volta;

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Index(FormCollection collection)
{
  MonthlyItemsFormViewModel fvm = new MonthlyItemsFormViewModel();
  UpdateModel(fvm);
  FillData(fvm, DateTime.Parse(DateTime.Now.Year.ToString() + " " + fvm.SelectedMonth + " 01"));
  return View(fvm);
}

É no código no posto de volta que você pode pegar o valor selecionado do fvm e depois casar com esse valor com um item em sua lista de seleção.

este código levantada diretamente do meu código para ser necessário modificar para se adequar a sua situação.

Isso faz sentido?

Respondeu 27/08/2009 em 04:59
fonte usuário

votos
0

Algum código do que você já tentou seria útil aqui kurozakura.

Enquanto isso;

Se você tiver vinculado a sua opinião sobre um modelo, em seguida, você pode usar UpdateModel para obter o valor de volta.

Então, se você vincular a uma classe chamada User então;

User myUser = new User;
TryUpdateModel(myUser);

Se você não tiver o envolveram, em seguida, usar a técnica de Eduardo e usar algo como;

public ActionResult MyViewsAction(FormCollection collection)
{
  string a = collection["selectListCtrlname"];
}
Respondeu 27/08/2009 em 04:21
fonte usuário

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more