在提交表单之前,我需要验证用户的输入字段值.
我已经在我的自定义控制器中创建了一个动作,并用它来装饰了它:
[Remote("CheckValue","Validate"),ErrorMessage="Value is not valid"] public string Value { get; set; }
问题是当我按提交,表单正在提交,然后如果用户输入的值无效,则显示“无效”消息.
如何验证用户输入的值,如果值无效,则阻止提交表单,并显示错误消息?
如果我尝试使用JavaScript检查表单是否有效$(“#formId”).valid()返回true,这意味着无论该值的状态是什么(有效还是无效)表单都是有效的.
另一方面,如果我使用[必需]属性来装饰另一个字段,则表单不会被提交,并且为该字段显示所需的错误.但是,远程验证字段的场景后面不会发生验证.
解决方法
远程验证在MVC中的完整解决方案.它将检查数据库中的电子邮件,然后检查数据库中是否存在,然后显示错误:
Email already exists
帐号控制器动作
[AllowAnonymous] [HttpPost] public ActionResult CheckExistingEmail(string Email) { try { return Json(!IsEmailExists(Email)); } catch (Exception ex) { return Json(false); } } private bool IsEmailExists(string email) => UserManager.FindByEmail(email) != null;
2.添加模型验证
[required] [MaxLength(50)] [EmailAddress(ErrorMessage = "Invalid Email Address")] [System.Web.Mvc.Remote("CheckExistingEmail","Account",HttpMethod = "POST",ErrorMessage = "Email already exists")] public string Email { get; set; }
3.添加脚本
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script> <script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
它可能会帮助你.谢谢