加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

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" />

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读