asp.net-mvc - 使用嵌套显示模板时如何防止 Razor 向输入添加前缀?

标签 asp.net-mvc razor model display-templates

当我使用嵌套显示模板并通过 HTML 帮助程序添加输入元素时,Razor 引擎会为字段名称添加前缀。

我知道这样做是为了保证页面级别的输入名称唯一性(并在回发时重建整个模型)。

但是,我有许多执行临时操作的小表单,我既不需要名称唯一性,也不需要重建整个模型的能力。

我只需要那个单一的属性值,当我提交其中一个表单时,让 Razor 更改输入项名称会破坏模型绑定(bind)器,因为所有名称都会不同。

此示例包含一个简化的嵌套模型

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; }
}

它有一个 Index具有三个嵌套显示模板的 View
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>

在请求的另一边,我的 Controller 操作收到成绩 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" />

其中字段名称获取基于整个父 View 模型树的前缀。

使用“手动”助手

@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在您的 Grade模板:

@model Playground.Sandbox.Models.Home.Index.Grade

@{
    ViewData.TemplateInfo.HtmlFieldPrefix = "";
}

这给出了所需的输出:
<input id="GradeId" name="GradeId" type="hidden" />

关于asp.net-mvc - 使用嵌套显示模板时如何防止 Razor 向输入添加前缀?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18595565/

相关文章:

javascript - 使用 jQuery 的 HTML 表 td 取消选择不起作用

asp.net-mvc - Url.Action 如何从模型添加参数值

python - 如何在django中根据结束日期自动删除记录

typescript - 是否有与 TypeScript 兼容的方式来使用 Sequelize 访问关联实体?

c# - 使用和或运算符的 Mongodb c# 过滤器

asp.net-mvc - 使用 DBContext Entry.OriginalValues 和 Entry.NewValues 记录更改的值

c# - 提交表单上的提醒确认框

core-data - 使用 CoreData 进行良好的设计?

asp.net-mvc - ASP.NET MVC - 表单上的多个按钮

razor - 为什么我不能在 App_Code 文件夹中的 Razor 助手 View 文件中使用 Html.RenderPartial?