constructor de entrada para un DropDownList con datos de DB en contrib mvc
-
19-09-2019 - |
Pregunta
Tengo algo como esto
public class Person
{
public Country {get; set;}
}
public class PersonInput
{
public ImNotSureWhatShouldIUseHere Country {get; set;}
}
no es un constructor de entrada para enumeraciones en contrib MVC pero no es bueno para mí porque puedo recuperar los datos de la base de datos y ahorro el Id del elemento seleccionado no el valor
Solución
i conseguido hacer un constructor de entrada de la mía, 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>
y la propiedad en la clase de entrada es como sigue:
[PartialView("MySelectList")]
public IEnumerable<SelectListItem> Om { get { return new SelectList(Web.Models.DataGenerator.Persons, "Id", "Name", 2); } }
Otros consejos
Vamos a tratar de recapitular lo que entendí de su pregunta: usted tiene un countries
tabla de base de datos que contiene las columnas id
y name
que le gustaría unirse a un elemento select
en una vista. Si esto es correcto podría intentar hacer algo como esto:
public ActionResult Index()
{
IEnumerable<Country> countries = FetchCountriesFromDB();
var model = new SelectList(countries, "Id", "Name", null);
return View(model);
}
Y en su opinión inflexible:
<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<System.Web.Mvc.SelectList>" %>
...
<%= Html.DropDownList("country", Model) %>
y, finalmente, usted podría tener una acción que usted publique en:
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Index(string country)
{
// country will contain the selected country id
...
}