I'm trying to populate a DropDownList and to get the selected value when I submit the form:
Here is my model :
public class Book
{
public Book()
{
this.Clients = new List<Client>();
}
public int Id { get; set; }
public string JId { get; set; }
public string Name { get; set; }
public string CompanyId { get; set; }
public virtual Company Company { get; set; }
public virtual ICollection<Client> Clients { get; set; }
}
My Controllers :
[Authorize]
public ActionResult Action()
{
var books = GetBooks();
ViewBag.Books = new SelectList(books);
return View();
}
[Authorize]
[HttpPost]
public ActionResult Action(Book book)
{
if (ValidateFields()
{
var data = GetDatasAboutBookSelected(book);
ViewBag.Data = data;
return View();
}
return View();
}
My Form :
@using (Html.BeginForm("Journaux","Company"))
{
<table>
<tr>
<td>
@Html.DropDownList("book", (SelectList)ViewBag.Books)
</td>
</tr>
<tr>
<td>
<input type="submit" value="Search">
</td>
</tr>
</table>
}
When I click, the parameter 'book' in the Action is always null. What am I doing wrong?
You can use DropDownListFor as below, It so simpler
(You need a strongly typed view for this -- View bag is not suitable for large lists)
I think this is simpler to use.
In HTML a dropdown box sends only simple scalar values. In your case that would be the id of the selected book:
and then adapt your controller action so that you will retrieve the book from the id that gets passed to your controller action: