ASP.NET MVC 3:当BeginForm在布局上时生成不显眼的验证

Rod*_*ero 7 unobtrusive-validation asp.net-mvc-3

我刚刚意识到,当我在布局页面上放置一个表单标签,围绕RenderBody部分时,不会生成不显眼的验证.像这样的东西:

@using (Html.BeginForm())
{
    <input type="submit" value="save" />

    <div>
        @RenderBody()
    </div>
}
Run Code Online (Sandbox Code Playgroud)

您可能已经猜到我想在我的内容上生成按钮.这是不正确的不引人注意的行为吗?

顺便说一句,如果我将表单放在特定页面中,一切都像魅力一样:data-val*属性生成良好.

我很感激你的宝贵帮助.

最好的祝福

罗德里戈

Dar*_*rov 12

您可以在视图中应用怪诞的黑客攻击:

@{
    var originalContext = ViewContext.FormContext;
    ViewContext.FormContext = new FormContext();
}

<!-- This will generate proper HTML5 data-* validation attributes -->
@Html.TextBoxFor(x => x.Prop1)
@Html.ValidationMessageFor(x => x.Prop1)

@Html.TextBoxFor(x => x.Prop2)
@Html.ValidationMessageFor(x => x.Prop2)

@{
    ViewContext.FormContext = originalContext;
}
Run Code Online (Sandbox Code Playgroud)

  • 这为我节省了相当多的工作,它真的是愚蠢的框架无法处理这个开始.我的意思是从ajax构建动态表单元素是一种非常常见的做法,如果你可以传入一个"模拟"新表单上下文来获取一个编辑器模板,那么就没有理由他们不能在顶部执行此操作处理编辑器模板的函数. (2认同)

Rod*_*ero 1

感谢您的帮助,我尝试了,但我找到了一个解决方案,不像您建议的那样“怪诞”(如您所说):D

我只是在页面中放置一个 BeginForm 方法,并在布局上放置一个 BeginForm 方法:

@* On the layout page *@
@using (Html.BeginForm())
{
    <input type="submit" value="save" />

    <div>
        @RenderBody()
    </div>
}


@* On the content page *@
@using(Html.BeginForm())
{
  @* Content *@
}
Run Code Online (Sandbox Code Playgroud)

所以,最后我有两个 BeginForm 方法: ASP.NET MVC 引擎使用位于布局页面上的方法,因此 data-val* 属性被正确呈现,并且表单放置在我想要的位置,因此任何提交按钮在布局上可以提交我的特定页面并呈现验证

效果很好

多谢

问候, 罗德里戈