asp.net-mvc – 使用嵌套显示模板时如何防止Razor向输入添加前缀
发布时间:2020-12-15 19:16:29 所属栏目:asp.Net 来源:网络整理
导读:当我使用嵌套显示模板并通过 HTML帮助器添加输入元素时,Razor引擎为字段名称添加一个前缀. 我明白这是为了保证页面级别的输入名称唯一性(并在后面重建整个模型). 但是,我有很多小型表单可以进行特别的操作,我不需要任何名称的唯一性,也不需要重建整个模型的
当我使用嵌套显示模板并通过
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" /> 这是我想要的. 是否可以实现我想要的,或者我得到显示模板的错误? 解决方法
您要在您的成绩模板中设置ViewData.TemplateInfo.HtmlFieldPrefix:
@model Playground.Sandbox.Models.Home.Index.Grade @{ ViewData.TemplateInfo.HtmlFieldPrefix = ""; } 这给出了所需的输出: <input id="GradeId" name="GradeId" type="hidden" /> (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp-classic – 多个错误如果那么,否则如果
- asp.net-mvc – 如何全局化ASP.NET MVC视图(特别是小数分隔
- 如何限制文件夹访问在asp.net
- asp.net-mvc – ASP.Net MVC加载进度指标
- asp.net – 当AutoGenerateColumns =“true”时动态设置gri
- ASP.NET Webforms,用户控件中的JavaScript
- [亲测]七步学会ASP.NET Core 2.0怎么发布/部署到Ubuntu Lin
- asp.net-core – 如何使用TeamCity使用WebDeploy部署ASP.NE
- asp.net – 扩展方法必须在非泛型静态类中定义
- asp.net – 如何将一个对象序列化为查询字符串格式?
推荐文章
站长推荐
- asp.net-mvc – 为什么调用base.OnActionExecuti
- asp.net-mvc-4 – ASP.Net MVC JS / CSS捆绑在部
- asp.net-mvc – 如何使用MSBuild部署一个ASP.NET
- asp.net-core – ASP.NET 5中RegisterObject / Q
- .net – 什么是dnu换行?
- asp.net-mvc – RouteCollection.Ignore和RouteC
- asp.net core 读取连接字符串
- 三重报价?如何在ASP.NET中分隔数据绑定的JavaSc
- asp.net-mvc-4 – MVC 4.5 Web API路由无法正常工
- asp.net-mvc – LiveReload ASP.net MVC Web应用
热点阅读