MVC3 Remove ModelState Errors
I've got a situation where I'm uploading an image the user has selected from his local file system. My Form in my view, basically has two submit buttons. One is used to Submit the form normally, and all validation executes. The 2nd is only for uploading the image, in which case I don't want to validate yet.
I managed to turn off Client Side validation by giving my 'Upload Image' submit button an a class value of "style-name cancel" , so
<input type="submit" name="UploadImageButton" value="Upload Image" class="style-name cancel" />
Now, when I post back, my model has a property UploadImageButton, when this button is clicked, it populates this property (Name of the input matches the Property). This way, I know whether the form was submitted by my true Submit button or by the UploadImageButton.
My question is this... How can I turn off ServerSide validation? I don't want the Validation Summary info showing up when the user clicks this button. I know you can add custom model errors using this
ModelState.AddModelError("{key}", "{error msg}");
I'm looking for a means to Remove Model Errors. Is this possible?
EDIT:
Here is what I came up with:
foreach (var key in ModelState.Keys.ToList().Where(key => ModelState.ContainsKey(key))) {
//ModelState.Remove(key); //This was my solution before
ModelState[key].Errors.Clear(); //This is my new solution. Thanks bbak
}
You can remove model errors by doing something like this:
if (ModelState.ContainsKey("{key}"))
ModelState["{key}"].Errors.Clear();
This builds off previous answers, but simplifies it a little more:
foreach (var modelValue in ModelState.Values)
{
modelValue.Errors.Clear();
}
In general, you don't want to turn off the server-side validation or remove ModelState errors manually. It's doable, but error-prone since it must rely on strings as keys. I upvoted the answer on how to remove the keys, because it is correct and useful, but I recommend against designing yourself into a case where you must strongly consider it.
In your case, you have multiple submit buttons for the same form, but you really aren't submitting the form when you upload the image. To prevent the client-side validation, you can use the "cancel" class as you've already indicated, but I also recommend having the 2nd submit button in a different form, in which case it causes no validation on your main form.
There is a second advantage to using the different form: you can send it to a different ActionResult method which would just handle the logic of uploading the image. This different method would simply not bother to check the "IsValid" property of the model state: it only cares if there is information in the image, and that can be checked separately. (Even if you use the same ActionResult method, you can funnel the logic so that you don't rely on the IsValid property of the model state.)
If you must clear the errors from the model state, and it makes sense to clear all of them, try this:
foreach (var key in ModelState.Keys)
{
ModelState[key].Errors.Clear();
}
This keeps you from depending on getting the key names correct, but preserves the values should any values (valid or invalid) already exist in the model.
One last thing to check for in these cases is whether you have values that are only sometimes in the view, which will not cause client-side validation (they're not in the view), but do result in server-side validation issues. In this case, it's best to use @Html.HiddenFor(model => model.PropertyName, if you can, assuming the value has already been set, it just isn't visible in this view.