我有一个带有 Html.BeginForm() 的视图,它调用在主视图模型中传递的部分视图(下面提到并且没有表单)。该模型具有数据注释。
如果我在不选择正确值的情况下尝试提交,则页面验证的初始加载效果很好。
我在页面上还有另一个按钮,如果单击它会加载页面上相同局部视图的另一个实例,使用 $.ajax() 发布到控制器,它只返回 PartialView,并将其附加到现有的 div。
如果我现在尝试提交这些动态控件的表单,尽管它们绑定到同一个模型并且虽然我设置了正确的 .ValidationMessageFor 助手,但它们不会出现验证,因为这些控件似乎不是使用 data-val 生成的* 属性。
我使用 fiddler 并发现 $.ajax 发布到控制器,生成带有简单且没有生成的 ValidationMessage 的部分视图。因此不能使用不显眼的 javascript 来添加动态控件。
是否有必要始终将视图放在表单中?在这种情况下,我将有嵌套的表单,这将无法正常工作。
编辑 1:正如 Adam Tuliper 在问题ViewContext.FormContext = new FormContext 中所提到的,生成了具有所有 data-val* 属性的部分视图。因此回答了我上面的问题。现在动态内容的验证没有触发。所以根据Erick(在评论部分),我删除了表单验证器 [form.removeData('validator');] 然后它也开始验证动态内容。
下面是部分视图
<div id="divVehicleInfo">
<fieldset>
<legend>Vehicle Information</legend>
@for (var i = 0; i < Model.QuoteInput.Vehicle.Count(); i++)
{
<div class="editor-label">
@Html.LabelFor(model => model.Vehicle[i].VehicleMake)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Vehicle[i].VehicleMake)
@Html.ValidationMessageFor(model => model.Vehicle[i].VehicleMake)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Vehicle[i].VehicleModel)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Vehicle[i].VehicleModel)
@Html.ValidationMessageFor(model => model.Vehicle[i].VehicleModel)
</div>
}
</fieldset>
</div>
这是局部视图的模型
public class Vehicle
{
public int VehicleID { get; set; }
[Required]
[DisplayName("Vehicle Make")]
public string VehicleMake { get; set; }
[Required]
[DisplayName("Vehicle Model")]
public string VehicleModel { get; set; }
}