当我使用嵌套显示模板并通过
HTML帮助器添加输入元素时,Razor引擎为字段名称添加一个前缀.
我明白这是为了保证页面级别的输入名称唯一性(并在后面重建整个模型).
但是,我有很多小型表单可以进行特别的操作,我不需要任何名称的唯一性,也不需要重建整个模型的能力.
我只需要这个单一的属性值,并且当我提交一个表单时,让Razor改变输入项名称会打破模型绑定,因为所有的名称都会不同.
此示例包含一个简化的嵌套模型
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; } }
它具有三个嵌套显示模板的索引视图
IndexView StudentDisplayTemplate CourseDisplayTemplate GradeDisplayTemplate
@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>
并且在请求的另一方,我的控制器操作接收成绩ID
public ActionResult Remove(Guid id) { // Do varIoUs things. return this.RedirectToAction("Index"); }
如果我尝试使用模型助手
@Html.HiddenFor(x => x.Id)
我得到了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" />
使用“手动”帮手
@Html.Hidden("GradeId",this.Model.Id)
给出HTML元素
<input id="Courses_0__Grades_0__GradeId" name="Courses[0].Grades[0].GradeId" type="hidden" value="bbb3c11d-d2d0-464a-b33b-ff7ac9815601" />
前缀仍然存在,尽管我的名字在最后.
手动添加隐藏输入
<input name="GradeId" type="hidden" value="@this.Model.Id" />
给出HTML元素
<input name="GradeId" type="hidden" value="a1a35e81-29cd-41b5-b619-bab79b767613" />
这是我想要的.