我在部分视图中有一个表单,该表单在选项卡控件的选项卡内呈现,如下所示:
@model USARAFSyncMVC.Areas.Event.Models.EventFullScaffoldModel
@using (Ajax.BeginForm("SaveMainEventDetails", "Event", new { area = "Event" },
new AjaxOptions { UpdateTargetId = "FormWrapper", OnComplete = "SetSuccessLabel", InsertionMode = InsertionMode.Replace },
new { method = "post" }))
{
@Html.Hidden("eventType", "1", new { id = "eventType" })
<div id="FormWrapper">
<hr />
<table border="0">
<tr>
<td>Title</td>
<td>@Html.TextBoxFor(model => model.Title, new { style = "width:300px" })
@Html.ValidationMessageFor(model => model.Title)</td>
</tr>
<tr>
<td>OPR</td>
<td> @Html.EditorFor(model => model.OPRID)</td>
</tr>
<tr>
<td>Organization</td>
<td> @Html.EditorFor(model => model.DomainID)</td>
</tr>
<tr>
<td>POC</td>
<td> @Html.EditorFor(model => model.POC)</td>
</tr>
<tr>
<td>Location</td>
<td>
@Html.EditorFor(model => model.LocationID)
</td>
</tr>
<tr>
<td>Dates</td>
<td>
<table>
<tr>
<th>@Html.LabelFor(m => m.StartDate)</th>
<th> @Html.LabelFor(m => m.EndDate)</th>
</tr>
<tr>
<td> @Html.EditorFor(m => m.StartDate)</td>
<td>@Html.EditorFor(m => m.EndDate)</td>
</tr>
</table>
<table id="DeployRedeployDiv">
<tr>
<th>Deploy</th>
<th>ReDeploy</th>
</tr>
<tr>
<td> @Html.EditorFor(m => m.EstimatedDeployDate)</td>
<td>@Html.EditorFor(m => m.EstimatedReDeployDate)</td>
</tr>
</table>
</td>
</tr>
<tr>
<td>OSRs</td>
<td>
@(Html.Telerik()
.PanelBar()
.Name("PanelBar")
.HtmlAttributes(new { style = "width:300px;" })
.Items(o => o.Add().Text("Click").Content(@<text>
@Html.CheckBoxList("OprList",
x => x.OprList,
x => x.OPRID,
x => x.AltTitle,
x => x.EventOSRs, Position.Vertical)</text>).Expanded(false)))
</td>
</tr>
<tr>
<td>Purpose</td>
<td> @Html.TextBoxFor(model => model.Why, new { style = "width: 400px; height:200px" })</td>
</tr>
<tr>
<td>Background</td>
<td> @Html.TextBoxFor(model => model.What, new { style = "width: 400px; height:200px" })</td>
</tr>
<tr>
<td>Viewable</td>
<td> @Html.CheckBoxFor(model => model.Viewable)</td>
</tr>
</table>
<div>
<input class="t-button" type="submit" name="button" value="Save" />
</div>
</div>
}
这是控制器:
[HttpPost]
public ActionResult SaveMainEventDetails(EventFullScaffoldModel model, string[] OprList, string eventType, string cbLoc, string cbOpr, string cbOrg)
{
if (OprList != null)
{
model.EventOSRs = miscRepository.GetOprsList().ToModel().Where(o => OprList.Contains(o.OPRID.ToString())).ToList();
}
model.Type = int.Parse(eventType);
model.LocationID = cbLoc;
model.OPRID = int.Parse(cbOpr);
model.DomainID = int.Parse(cbOrg);
eventRepository.Insert(model.ToDto());
return View();
}
以下是模型:
public partial class EventFullScaffoldModel
{
public Int32 EventID { get; set; }
[Required(ErrorMessage = "Required!")]
public String Title { get; set; }
[Required(ErrorMessage = "Required!")]
[DataType(DataType.Date)]
[DisplayFormat(DataFormatString = "{0:dd-MM-yyyy}")]
public DateTime StartDate { get; set; }
[Required(ErrorMessage = "Required!")]
[DataType(DataType.Date)]
[DisplayFormat(DataFormatString = "{0:dd-MM-yyyy}")]
public DateTime EndDate { get; set; }
[Required(ErrorMessage = "Required!")]
public String What { get; set; }
[Required(ErrorMessage = "Required!")]
public String Why { get; set; }
public Nullable<DateTime> Modified { get; set; }
public String ModifiedBy { get; set; }
public Nullable<DateTime> Created { get; set; }
public String CreatedBy { get; set; }
[UIHint("ActiveDirectoryLoadOnDemand"), Required]
public String POC { get; set; }
[DataType(DataType.Date)]
[DisplayFormat(DataFormatString = "{0:MM-dd-yyyy}")]
public Nullable<DateTime> EstimatedDeployDate { get; set; }
[DataType(DataType.Date)]
[DisplayFormat(DataFormatString = "{0:MM-dd-yyyy}")]
public Nullable<DateTime> EstimatedReDeployDate { get; set; }
public Nullable<Int32> TSCMISID { get; set; }
public Nullable<Int32> ReviewStatus { get; set; }
public int? Type { get; set; }
public String InactivityReason { get; set; }
public Boolean Viewable { get; set; }
public string OPRAltTitle { get; set; }
[UIHint("OprDropDown"), Required]
public int OPRID { get; set; }
[UIHint("OrgDropDown"), Required]
public int DomainID { get; set; }
[UIHint("LocationsLoadOnDemand"), Required]
public string LocationID { get; set; }
public string LocationTitle { get; set; }
public IList<OsrModel> EventOSRs { get; set; }
public IList<TargetAndEffectModel> EventTargetEffects { get; set; }
public IList<AssociationModel> EventAssociations { get; set; }
public IList<EventObjectiveModel> EventObjectives { get; set; }
public IList<StrategicObjectiveModel> EventTSOs { get; set; }
public IList<TaskModel> EventTasks { get; set; }
public IList<PaxModel> EventPaxBreakDowns { get; set; }
public IList<FundingModel> EventFundings { get; set; }
public IList<UnitModel> EventExecutingUnits { get; set; }
public IList<OsrModel> OprList { get; set; }
public IList<ObjectiveModel> ObjectiveList { get; set; }
public IList<StrategicObjectiveModel> StrategicList { get; set; }
public IList<OrgModel> OrgsList { get; set; }
}
模型永远不会得到验证,直接在控制器上运行事务。为什么这不起作用?
答案 0 :(得分:4)
我建议首先检查您是否已按正确的顺序包含必要的javascript文件以进行不显眼的验证,这将使验证在客户端成功完成。
关于服务器端验证,基本上你必须通过显式检查ModelState.IsValid
将模型保存到数据库。由于您正在进行AJAX调用,我建议您将模型状态错误作为JSON返回。
因此,在OnFailure
的{{1}}方法中,您可以解析JSON并将错误显示为div中的摘要。
基本上你可以遵循这种模式。
AjaxOptions
答案 1 :(得分:2)
您需要明确检查操作中是否ModelState.IsValid
,如果不是,则返回编辑视图。
如果显示无效模型的编辑视图,MVC将通过验证帮助程序自动显示错误消息。
答案 2 :(得分:0)
这应该有所启发: What is ModelState.IsValid valid for in ASP.NET MVC in NerdDinner?
基本上,您必须使用ModelState.IsValid
答案 3 :(得分:0)
在视图中添加@{ Html.EnableClientValidation(); }
并参考该链接了解更多详情How to: Validate Model Data Using DataAnnotations Attributes
答案 4 :(得分:0)
好的问题是Telerik Script Registrar没有引用正确的JQuery。现在它正在运作。我直接引用了JQuery库,还有验证脚本。在Telerik脚本注册器上,它已经是默认组的一部分,正如我正在做的那样重新引用它们,导致它因某些原因而变得惊慌失措。仅添加对原始默认组不属于的脚本的引用。有关这方面的更多信息,需要阅读此MVC扩展的在线文档。