ASP.NET pubblica un modulo con il modello di visualizzazione del modello di controllo del controller
-
21-12-2019 - |
Domanda
Ho una forma abbastanza complessa che ho bisogno di pubblicare il mio controller MVC.
Ecco il modello di vista che inizialmente passerò alla vista sulla creazione:
public class EditViewModel
{
public Service service { get; set; }
public bool sms { get; set; }
public bool email { get; set; }
public string userId { get; set; }
}
.
Ecco la mia opinione (semplificata):
@model IList<Service_Monitor_Web_Interface.Models.ViewModels.EditViewModel>
@{
ViewBag.Title = "Configure User Notifications";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>@ViewBag.Title</h2>
@using (Html.BeginForm("Edit", "Users", FormMethod.Post, new { @class = "stdform stdform2", role = "form" }))
{
@Html.AntiForgeryToken()
<hr />
<p>
<label><u> Service:</u> </label>
<span class="field">
<u>Notification Methods:</u>
</span>
</p>
for (int i = 0; i < Model.Count; i++)
{
<p>
<label>@Model[i].service.Name</label>
<span class="field">
@Html.CheckBoxFor(model => model[i].sms)
SMS
@Html.CheckBoxFor(model => model[i].email)
Email
</span>
</p>
}
<br clear="all" /><br />
<p class="stdformbutton">
<button class="submit radius2">Save</button>
<input type="reset" class="reset radius2" value="Reset Form" />
</p>
}
.
Ed ecco il mio metodo di azione nel mio controller:
//
// POST: /Users/Edit
[HttpPost]
public ActionResult Edit(IList<EditViewModel> viewModel)
{
return View(viewModel);
}
.
Come posso associare il mio modello di visualizzazione quando lo ricevi sul controller? Attualmente quando debug del metodo di azione riceve un mirino che sembra così:
Come posso ottenere servizio e userid non essere nullo?
Soluzione
Si noti che negli Lambdas dei tuoi aiutanti, ad esempio nella parte model => service.sms
Destra (service.sms
) formalmente non deriva dalla parte sinistra (model
).Ciò causa che tutti gli attributi name
degli input risultanti siano uguali, e ti dà dei parametri di richiesta che non ti aspettavi.
La pratica standard è quella di utilizzare for
instabile di foreach
in casi di loop.In questo modo gli attributi del nome per l'HTML risultante sono generati correttamente:
for(int i=0; i<Model.Count; i++)
{
<p>
<label>@Model[i].service.Name</label>
<span class="field">
@Html.CheckBoxFor(model => model[i].sms)
SMS
@Html.CheckBoxFor(model => model[i].email)
Email
</span>
</p>
}
.
Si noti che ciò richiede Model
da essere di tipo implementazione generacolotetagcode anziché IList
.
Aggiornamento. Per altri valori, che non hanno alcuna UI per loro, è possibile utilizzare campi nascosti, in modo che non siano visibili per l'utente e non è comunque pubblicato sul server:
.<label>@Model[i].service.Name</label>
<span class="field">
@Html.CheckBoxFor(model => model[i].sms)
SMS
@Html.CheckBoxFor(model => model[i].email)
Email
@Html.HiddenFor(mode => model[i].userId)
@Html.HiddenFor(mode => model[i].service.Name)
...other field of service you want to be posted...
</span>
.