In meiner Anwendung habe ich eine Dropdown-Liste, um verschiedene Auswahlmöglichkeiten darzustellen. Beachten Sie, dass Paragraph
ein Modell ist und der Abschnitt nur ein Feld im Modell ist.MVC 3 Dropdown-Liste, die nicht an Modell
Und hier ist mein Controller.
public ActionResult Edit(int id)
{
var paragraph = db.Paragraphs.Find(id);
ViewBag.Sections = new SelectList(
db.Sections.Select(s => new { s.ID, s.Name }),
"ID", "Name", paragraph.SectionID
);
return View(paragraph);
}
[HttpPost]
public ActionResult Edit(Paragraph paragraph, HttpPostedFileBase document)
{
if (ModelState.IsValid)
{
// Do some stuff.
}
ViewBag.Sections = new SelectList(
db.Sections.Select(s => new { s.ID, s.Name }),
"ID", "Name", paragraph.SectionID
);
return View(paragraph);
}
Wenn ich das Formular absende, ist die Dropdown-Liste nicht an das Modell gebunden. ModelState.IsValid
zu verursachen, um falsch zu sein und mein Leben schrecklich zu machen. Irgendwelche Vorschläge?
EDIT: Wenn ich die Form ich folgende Fehlermeldung erhalten einreichen:
There is no ViewData item of type 'IEnumerable<SelectListItem>' that has the key 'Sections'.
EDIT: Es scheint, dass ich die vorhergehenden Fehler nur, wenn ich versuche, die Datei zu senden.
EDIT: Modell
public class Paragraph
{
public int ID { get; set; }
[Required]
public int Major { get; set; }
[Required]
public int Minor { get; set; }
[Required(ErrorMessage = "Name is required")]
[StringLength(4000)]
public string Name { get; set; }
public int SectionID { get; set; }
public virtual Section Section { get; set; }
}
Form: (. Es ist viel)
<form class="form-horizontal" action="/Paragraph/Edit" method="post" enctype="multipart/form-data">
<fieldset>
<div class="control-group">
<label class="control-label" for="section">Section</label>
<div class="controls">
@Html.DropDownList("Sections")
</div>
</div>
<div class="control-group">
<label class="control-label" for="major">Major</label>
<div class="controls">
<input type="number" class="input-large" name="major" value="@Model.Major" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="minor">Minor</label>
<div class="controls">
<input type="number" class="input-large" name="minor" value="@Model.Minor" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="name">Name</label>
<div class="controls">
<input type="text" class="input-large" name="name" value="@Model.Name" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="document">Document</label>
<div class="controls">
<input type="file" class="input-file" name="document" />
</div>
</div>
<div class="form-actions">
<input type="submit" class="btn btn-primary" value="Save" />
<a class="btn" href="/Paragraph/Show/@Model.ID">Cancel</a>
</div>
</fieldset>
</form>
Die Verwendung von ViewModels und stark typisierten Helfern ist im Allgemeinen der richtige Weg. Ich bin froh, dass du es sortiert hast. – GraemeMiller