Je vous suggère d'utiliser une vue fortement typée (pas besoin de ViewData
et de chaînes magiques). Comme toujours commencer par définir votre point de vue modèle classe:
public class CountriesViewModel
{
public int? SelectedCountryId { get; set; }
public IEnumerable<SelectListItem> Countries { get; set; }
}
Ensuite, votre contrôleur:
public class HomeController : Controller
{
public ActionResult Index(int? id)
{
// TODO: Fetch those from your DB
var countries = new[]
{
new { Id = 1, Name = "Country 1" },
new { Id = 2, Name = "Country 2" },
};
var model = new CountriesViewModel
{
Countries = new SelectList(countries, "Id", "Name", id)
};
return View(model);
}
}
Et enfin votre point de vue fortement typé:
<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<SomeNs.Models.CountriesViewModel>" %>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<%= Html.DropDownListFor(
x => x.SelectedCountryId,
Model.Countries,
"-- Select Country --")
%>
</asp:Content>
Maintenant, lorsque vous appelez /home/index
vous obtenez pas pays sélectionné, mais lorsque vous passez le id
à cette action comme /home/index/2
vous obtenez le pays avec cet identifiant sélectionné.
Remarque: Si vous utilisez ASP.NET MVC 1.0, vous n'avez pas l'aide DropDownListFor fortement typé et vous pouvez utiliser ceci:
<%= Html.DropDownList(
"SelectedCountryId",
Model.Countries,
"-- Select Country --")
%>
double possible: http://stackoverflow.com/questions/624828/asp-net-mvc-html-dropdownlist-selectedvalue – Gabe