ASP.NET MVC ViewModel and DropDownList

11,008

As womp said, a browser will only submit the selected value of a drop down list. This is easily bound by the default model binder, see below.

If you are not editing the PossibleValues list on the client then there is no need to submit them back. If you need to repopulate the list then do it server side in your post action by using the same method you originally populated the Dictionary with.

For example in you page:

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<ViewModel1>" %>
<!-- some html here -->
<%= Html.DropDownListFor(x => x.SelectedKey, new SelectList(Model.PossibleValues, "key", "value"))%>

In your controller

[AcceptVerbs(HttpVerbs.Get)]
public ViewResult Edit() {
 var model = new ViewModel1 {
   PossibleValues = GetDictionary()  //populate your Dictionary here
 };
 return View(model);
}

[AcceptVerbs(HttpVerbs.Post)]
public ViewResult Edit(ViewModel1 model) { //default model binding
  model.PossibleValues = GetDictionary();  //repopulate your Dictionary here
  return View(model);
}

Where GetDictionary() is a method that returns your populated Dictionary object.

See this similar question for more details

Share:
11,008
jameszhao00
Author by

jameszhao00

rabble

Updated on June 13, 2022

Comments

  • jameszhao00
    jameszhao00 almost 2 years

    I have 2 properties in my ViewModel

    class ViewModel1
    {
        Dictonary<int, string> PossibleValues {get;set;}//key/value
        int SelectedKey {get;set}
    }
    

    I want to edit this using a Html.DropDownListFor

    I want to get MVC to auto serialize the data into/from the ViewModel so I can the following

    public ActionResult Edit(ViewModel1 model) ...
    

    What's the best way to accomplish this?