我有一个编辑视图,带有一个选择列表和几个为可为空的日期字段生成的文本框。如果没有日期,则不进行验证 - 这是正确的。
但是,如果我输入了无效日期,则验证不会检测到该日期,并继续执行我的操作。如何强制验证日期字段?
我的模特:
public class CaseEmployer
{
public int Id { get; set; }
public int CaseId { get; set; }
public Company Company { get; set; }
[Display(Name = "Start Date")]
[DisplayFormat(DataFormatString = "{0:MM/dd/yyyy}", ApplyFormatInEditMode=true)]
public DateTime? StartDate { get; set; }
[Display(Name = "End Date")]
[DisplayFormat(DataFormatString = "{0:MM/dd/yyyy}", ApplyFormatInEditMode = true)]
public DateTime? EndDate { get; set; }
public int? UserId { get; set; }
public DateTime? TimeStamp { get; set; }
}
我的观点:
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)
<fieldset>
<legend>Employer</legend>
@Html.HiddenFor(model => model.Id)
@Html.HiddenFor(model => model.CaseId)
<div class="editor-label">
@Html.Label("Company:")
</div>
<div class="editor-field">
<select name="companySelect" id="companySelect">
@foreach (var company in ViewBag.CompanyOptions)
{
<option value="@company.Key">@company.Value</option>
}
</select>
</div>
<div class="editor-label">
@Html.LabelFor(model => model.StartDate)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.StartDate)
@Html.ValidationMessageFor(model => model.StartDate)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.EndDate)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.EndDate)
@Html.ValidationMessageFor(model => model.EndDate)
</div>
<p>
<input type="submit" value="Update" />
<input type="button" value="Cancel" onclick="javascript:window.close()" />
<input type="button" value="Delete" onclick="javascript:confirmDeleteCaseEmployer()" />
</p>
</fieldset>
**编辑**
我向类添加了“Required”属性以测试验证是否会触发,如果我提交了没有StartDate和EndDate的表单,并且验证确实触发了这些属性。
谢谢!
答案 0 :(得分:0)
如果您打算验证日期时间字段,您可能需要查看regularexpression validate属性,以帮助客户端不显眼的JavaScript验证预期的输入。您的displayformat属性不会影响验证,只会影响日期时间值的显示方式。
显示您的代码后,在表单发布到控制器操作之前,基本上不会发生任何验证。由于updatemodel无法将您的某些输入转换为日期时间值,因此您会收到模型格式转换错误。