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)
感谢您的帮助,我尝试了,但我找到了一个解决方案,不像您建议的那样“怪诞”(如您所说):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* 属性被正确呈现,并且表单放置在我想要的位置,因此任何提交按钮在布局上可以提交我的特定页面并呈现验证
效果很好
多谢
问候, 罗德里戈
| 归档时间: |
|
| 查看次数: |
5469 次 |
| 最近记录: |