problemas com ASP MVC + Html.DropDownList () usando um padrão ModelView
Recentemente eu postei uma pergunta sobre o dropdownlist html helper e consegui trabalhar (Aqui). Mas agora eu decidi que era muito mais inteligente mudar para ModelView Patterns então eu tenho acesso a métodos fortemente tipados em minhas views, etc. O que eu fiz foi fazer alguns ajustes no código em meu outro tópico da seguinte maneira:
VacatureFormViewModel:
<code>public class VacaturesFormViewModel { public Vacatures Vacature { get; private set; } public SelectList EducationLevels { get; private set; } public SelectList Branches { get; private set; } public SelectList CareerLevels { get; private set; } Repository repository; // Constructor public VacaturesFormViewModel(Vacatures vacature) { this.Vacature = vacature; this.repository = new Repository(); this.EducationLevels = new SelectList(repository.GetAllEducationLevels(),"ID","Name",vacature.EducationLevels); this.Branches = new SelectList(repository.GetAllBranches(),"ID","Name",vacature.Branches); this.CareerLevels = new SelectList(repository.GetAllCareerLevels(), "ID", "Name", vacature.CareerLevels); } } </code>
BanenController:
<code>// // GET: /Banen/Create public ActionResult Create() { Vacatures vacature = new Vacatures(); return View(new VacaturesFormViewModel(vacature)); } // // POST: /Banen/Create [AcceptVerbs(HttpVerbs.Post)] public ActionResult Create(Vacatures vacatureToAdd) { if (ModelState.IsValid) { try { // TODO: Add insert logic here repository.AddToVacatures(vacatureToAdd); repository.SaveChanges(); // Return to listing page if succesful return RedirectToAction("Index"); } catch (Exception e) { return View(); } } } </code>
E minha visão Create.aspx (parte dela):
<code><% using (Html.BeginForm()) {%> <fieldset> <legend>Fields</legend> <p> <label for="Title">Title:</label> <%= Html.TextBox("Title", Model.Vacature.Title) %> <%= Html.ValidationMessage("Title", "*") %> </p> <p> <label for="Content">Content:</label> <%= Html.TextArea("Content", Model.Vacature.Content) %> <%= Html.ValidationMessage("Content", "*") %> </p> <p> <label for="EducationLevels">EducationLevels:</label> <%= Html.DropDownList("EducationLevels", Model.EducationLevels)%> <%= Html.ValidationMessage("EducationLevels", "*") %> </p> <p> <label for="CareerLevels">CareerLevels:</label> <%= Html.DropDownList("CareerLevels", Model.CareerLevels)%> <%= Html.ValidationMessage("CareerLevels", "*")%> </p> <p> <label for="Branches">Branches:</label> <%= Html.DropDownList("Branches", Model.Branches)%> <%= Html.ValidationMessage("Branches", "*")%> </p> <p> <input type="submit" value="Save" /> </p> </fieldset> <% } %> </code>
Para guiar eu usei oNerdDinner tutorial por ScottGu e eu li vários tópicos aqui.
Minha pergunta é se é possível deixar o MVC ASP definir meu careerlevel, educationlevel e branche (dropdownlists) automaticamente já que ele está retornando uma string de ID que não é o que eu quero. Quando eu mudo a criação do SelectList para:
<code>this.CareerLevels = new SelectList(repository.GetAllCareerLevels(), vacature.CareerLevels); </code>
Então, sem o "ID" e "Nome", ele não salva (eu acho que ainda é retornado como uma string no método post, e não o objeto em si) e ao lado disso, ele lista na visão como: vacature. EducationLevels etc. Portanto, não os nomes, mas o próprio objeto é listado.
Pergunta final Então, em suma, a minha pergunta é se é possível usar essa abordagem para definir meu quadro, nível educacional e nível de carreira. Então não automaticamente?
Nesse caso, ainda tenho que usar coisas como:
<code>[AcceptVerbs(HttpVerbs.Post)] public ActionResult Create(FormCollection form) { Vacatures vacatureToAdd = new Vacatures(); // Retrieve the education level by its ID if (!form["EducationLevels"].Equals("")) { Guid educationID = new Guid(form["EducationLevels"]); vacatureToAdd.EducationLevels = repository.GetEducationLevelByID(educationID); } </code>
No meu controlador? Ou existem outras opções mais suaves.