construtor de entrada para um DropDownList com dados de DB em contrib mvc
-
19-09-2019 - |
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
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
...
}