Je travaille sur une application MVC où la classe Model Item
a un List<Colour>
nommé AvailableColours
en tant que propriété.
AvailableColours
est un sous-ensemble défini par l'utilisateur de Colour
classes. Je souhaite afficher toutes les instances de Colour
dans une liste de cases à cocher et, une fois soumis, AvailableColours
est un List<Colour>
contenant les classes Colour
vérifiées.
Quelle est la meilleure façon de procéder dans MVC?
Edit: Mon code jusqu'à présent, même si je pense que ce n'est pas la façon la plus MVC de le faire!
Modèle
public class Item
{
public int ID { get; set; }
public List<Colour> AvailableColours { get; set; }
}
Voir
@model MyNamespace.Models.Item
@using MyNamespace.Models;
@{
ViewBag.Title = "Create";
var allColours = new List<Colour>(); //retrieved from database, but omitted for simplicity
}
<h2>Create New Item</h2>
@using (Html.BeginForm("Create", "Item", FormMethod.Post))
{
<div>
@Html.LabelFor(model => model.AvailableColours)
@foreach (var colour in allColours)
{
<input type="checkbox" name="colours" value="@colour.Description" />
}
</div>
<input type="submit" value="Submit" />
}
Contrôleur
[HttpPost]
public ActionResult Create(Item item, string[] colours)
{
try
{
foreach (var colour in colours)
{
item.AvailableColours.Add(GetColour(colour));//retrieves from database
return RedirectToAction("Index");
}
}
catch
{
return View();
}
}
Modèles
public class Item
{
public List<Colour> AvailableColours { get;set; }
}
public class Colour
{
public int ID { get; set; }
public string Description { get; set; }
public bool Checked { get; set; }
}
Notez la propriété Checked
Afficher la boucle
@using (Html.BeginForm("Create", "Item", FormMethod.Post))
{
<div>
@Html.LabelFor(model => model.AvailableColours)
@for(var i = 0; i < Model.AvailableColours.Count; i++)
{
@Html.HiddenFor(m => Model.AvailableColours[i].ID)
@Html.HiddenFor(m => Model.AvailableColours[i].Description)
@Html.CheckBoxFor(m => Model.AvailableColours[i].Checked)
@Model.AvailableColours[i].Description<br/>
}
</div>
<input type="submit" value="Submit" />
}
Notez la boucle for insted de foreach pour activer la liaison du modèle et les champs cachés pour permettre aux valeurs d'être renvoyées au contrôleur
Poste de contrôleur
[HttpPost]
public ActionResult Create(Item model)
{
//All the selected are available in AvailableColours
return View(model);
}
Assurez-vous d'ajouter le constructeur dans la classe et de déclarer la liste à l'intérieur. Sinon, il déclarerait la valeur null nulle que vous ne pourrez pas définir plus tard.
public class Item
{
public Item(){
AvailableColours =new List<Color>();
}
}