How to Fix Summary Error Display in C#
I'm working on a change password form when I encountered this strange behavior from mvc3. I created a simple form and change password mo...
https://www.czetsuyatech.com/2011/12/c-validation-error-fix.html
I'm working on a change password form when I encountered this strange behavior from mvc3. I created a simple form and change password model with 3 fields (old, new, confirm password). Then I extended ValidationAttribute to validate the password's length.
ValidatePasswordLengthAttribute
public class ValidatePasswordLengthAttribute : ValidationAttribute { private readonly int _minCharacters = Membership.Provider.MinRequiredPasswordLength; public override string FormatErrorMessage(string name) { return String.Format(CultureInfo.CurrentUICulture, ErrorMessageString, name, _minCharacters); } public override bool IsValid(object value) { var valueAsString = value as string; return (valueAsString != null && valueAsString.Length >= _minCharacters); } }Then on my form, I'm showing the error as: Field errors beside the field and page errors below. For the readers information field and page error can be added by:
//Field Error ModelState.AddModelError("Password", "Field Error(Password)"); //Page Error ModelState.AddModelError(string.Empty, "Page Error");Note that I've styled my validation-summary-errors div with red background. On form submit, I'm surprised to see a red div but with no content, a bug? So my solution is to simply check if there are visible li element under validation-summary-errors. Because after I submit it's css property display=none. Solution:
<script type="text/javascript"> //work around to the validation summary bug $(document).ready(function () { if ($(".validation-summary-errors li:visible").length == 0) { $(".validation-summary-errors").hide(); } }); </script>
Post a Comment