我刚刚意识到,当我在布局页面上放置一个表单标签,围绕RenderBody部分时,不会生成不显眼的验证.像这样的东西:
@using (Html.BeginForm()) { <input type="submit" value="save" /> <div> @RenderBody() </div> }
您可能已经猜到我想在我的内容上生成按钮.这是不正确的不引人注意的行为吗?
顺便说一句,如果我将表单放在特定页面中,一切都像魅力一样:data-val *属性生成良好.
我很感激你的宝贵帮助.
最好的祝福
罗德里戈
解决方法
您可以在视图中应用怪诞的黑客攻击:
@{ 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; }