Quando utilizzo i modelli di visualizzazione annidati e aggiungo elementi di input tramite l'helper HTML, il motore Razor aggiunge un prefisso ai nomi dei campi.Come impedire a Razor di aggiungere prefissi agli input quando si utilizzano modelli di visualizzazione annidati?
Capisco che questo è fatto per garantire l'unicità del nome di input a livello di pagina (e per ricostruire l'intero modello sul postback).
Tuttavia, ho molte piccole forme che eseguono azioni ad-hoc e non ho bisogno né dell'unicità del nome né della capacità di ricostruire l'intero modello.
Ho solo bisogno di quel valore di singola proprietà, e avendo Razor alterare i nomi degli elementi di input interrompe il raccoglitore del modello quando invio uno dei moduli, poiché tutti i nomi saranno diversi.
Questo esempio contiene un modello nidificato semplificato
public class Student
{
public Guid Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public List<Course> Courses { get; set; }
}
public class Course
{
public Guid Id { get; set; }
public string Name { get; set; }
public List<Grade> Grades { get; set; }
}
public class Grade
{
public Guid Id { get; set; }
public DateTime Date { get; set; }
public decimal Value { get; set; }
}
ed ha una Index
vista con tre modelli di visualizzazione annidati
IndexView
StudentDisplayTemplate
CourseDisplayTemplate
GradeDisplayTemplate
Nella maschera di visualizzazione grado aggiungo un pulsante per rimuovere il grado
@model Playground.Sandbox.Models.Home.Index.Grade
<li>
@this.Model.Date: @this.Model.Value
@using (Html.BeginForm("Remove", "Home", FormMethod.Post))
{
<input name="GradeId" type="hidden" value="@this.Model.Id" />
<input type="submit" value="Remove" />
}
</li>
e sull'altro lato della richiesta il mio azione di controllo riceve l'ID grado
public ActionResult Remove(Guid id)
{
// Do various things.
return this.RedirectToAction("Index");
}
Se provo a farlo utilizzando il modello di supporto
@Html.HiddenFor(x => x.Id)
ottengo l'elemento HTML
<input data-val="true"
data-val-required="The Id field is required."
id="Courses_0__Grades_1__Id"
name="Courses[0].Grades[1].Id"
type="hidden"
value="76f7e7ed-a479-42cb-add5-e58c0090770c" />
in cui il nome del campo ottiene un prefisso basato sull'albero del modello di visualizzazione dell'intero genitore.
Utilizzando l'aiutante "manuale"
@Html.Hidden("GradeId", this.Model.Id)
dà l'elemento HTML
<input id="Courses_0__Grades_0__GradeId"
name="Courses[0].Grades[0].GradeId"
type="hidden"
value="bbb3c11d-d2d0-464a-b33b-ff7ac9815601" />
dove il prefisso è ancora presente, anche se con il mio nome alla fine.
aggiungere manualmente l'input nascosto
<input name="GradeId" type="hidden" value="@this.Model.Id" />
dà l'elemento HTML
<input name="GradeId"
type="hidden"
value="a1a35e81-29cd-41b5-b619-bab79b767613" />
che è quello che voglio.
È possibile ottenere ciò che desidero oppure i problemi di visualizzazione dei modelli di visualizzazione sono errati?
http://stackoverflow.com/questions/14157376/why-does-html-helper-add-prefix-to-attributes-for-child-item-of-view-model –
@MohamadBataineh come ho detto, lo faccio sai perché lo sta facendo Quello che sto chiedendo è se c'è un modo per prevenirlo quando si usano gli helper HTML (non penso di poter usare l'attributo Bind nell'azione di ricezione, poiché gli helper stanno inserendo indici di array nei nomi). – Albireo