Pergunta

Eu tenho algo parecido com isto

public class Person
{
public Country {get; set;}

}

public class PersonInput
{
public ImNotSureWhatShouldIUseHere Country {get; set;}
}

não é um construtor de entrada para Enums em contrib MVC, mas não é bom para mim porque eu recuperar os dados do DB e eu salvar a identificação do elemento selecionado não o valor

Foi útil?

Solução

i conseguiu fazer um construtor de entrada do meu próprio, parece que este

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/InputBuilders/Field.Master"  
  Inherits="System.Web.Mvc.ViewPage<PropertyViewModel<object>>" %>
<%@ Import Namespace="MvcContrib.UI.InputBuilder.Views"%>
<%@ Import Namespace="System.Web.Mvc.Html"%>
<asp:Content ID="Content2" ContentPlaceHolderID="Input" runat="server">
    <%=Html.DropDownList(Model.Name, Model.Value as IEnumerable<SelectListItem>)%>    
</asp:Content>

e a propriedade na classe de entrada é assim:

 [PartialView("MySelectList")]
        public IEnumerable<SelectListItem> Om { get { return new SelectList(Web.Models.DataGenerator.Persons, "Id", "Name", 2); } }

Outras dicas

Deixe-me tentar recapitular o que eu entendi a sua pergunta: você tem uma tabela countries banco de dados que contém colunas id e name que você gostaria de vincular a um elemento select em uma exibição. Se isto estiver correto, você pode tentar fazer algo parecido com isto:

public ActionResult Index()
{
    IEnumerable<Country> countries = FetchCountriesFromDB();
    var model = new SelectList(countries, "Id", "Name", null);
    return View(model);
}

E na sua opinião fortemente tipificada:

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<System.Web.Mvc.SelectList>" %>
...
<%= Html.DropDownList("country", Model) %>

e, finalmente, você poderia ter uma ação que você postar em:

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Index(string country)
{
    // country will contain the selected country id
    ...
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top