我正在尝试向用户显示一些错误。
为此,我正在使用ModelState.isValid
和@Html.ValidationSummary
进行显示。
但是以某种方式,它目前无法正常工作。
型号:
[Required(ErrorMessage = "Account name is required")]
[EmailAddress]
public string CTC_accountName { get; set; }
[Required(ErrorMessage = "Password is required")]
[DataType(DataType.Password)]
public string CTC_accountPassword { get; set; }
控制器:
[HttpPost]
public async Task<IActionResult> Submit(RegisterViewModel model)
{
if (!ModelState.IsValid)
{
return View(model);
}
}
}
查看:
@using (Html.BeginForm("Submit", "Register", FormMethod.Post, new { id = "formAll", style = "margin-top:3%", enctype = "multipart/form-data" }))
{
<div class="shadow-sm p-2 mb-3 rounded">
<div class="col-sm-9">
<h5>Personal Details</h5>
</div>
</div>
<div id="formMember">
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<div class="form-group row">
<div class="col-sm-2">
@Html.LabelFor(model => model.CTC_accountName, "Account/Email*")
</div>
<div class="col-sm-10">
@Html.EditorFor(model => model.CTC_accountName, new { htmlAttributes = new { @class = "form-control", @placeholder = "Email", @id = "CTC_accountName", @autocomplete = "username" } })
</div>
<div class="col-sm-10">
@Html.ValidationMessageFor(model => model.CTC_accountName)
</div>
</div>
<div class="form-group row">
<div class="col-sm-2">
@Html.LabelFor(model => model.CTC_accountPassword, "Password*")
</div>
<div class="col-sm-10">
@Html.EditorFor(model => model.CTC_accountPassword, new { htmlAttributes = new { @class = "form-control", @placeholder = "Password", @id = "CTC_accountPassword", @type = "password", @autocomplete = "current-password" } })
</div>
<div class="col-sm-10">
@Html.ValidationMessageFor(model => model.CTC_accountName)
</div>
</div>
</div>
}
感谢您的帮助
答案 0 :(得分:0)
我发现了什么问题。
在提交功能中我有一个POST调用ajax,必须删除才能查看@ Html.ValidationSummary!