Looking for a way to hook into the client side fail condition for the form.
I need to re-enable a submit button if the validation fails so they can try again.
I found the following: Using unobtrusive validation in ASP.NET MVC 3, how can I take action when a form is invalid? which might work but I was hoping to do this from a central place as the form can be submitted from several places.
Update:
This function seems to work well assuming you have an input tag with the class ".goButton".
<script language="javascript" type="text/javascript">
$(".goButton").click(function () {
if (!$(this).closest("form").valid()) {
return false;
}
$(".goButton").after("Please wait...");
$(".goButton").hide();
});
</script>
Unobtrusive Validation means without writing a lot of validation code, you can perform simple client-side validation by adding the suitable attributes and including the suitable script files. data-val-required=”This is required.”
You can disable the unobtrusive validation from within the razor code via this Html Helper property: HtmlHelper. ClientValidationEnabled = false; That way you can have unobtrusive validation on and off for different forms according to this setting in their particular view/partial view.
validator. unobtrusive. parse(selector) method to force parsing. This method parses all the HTML elements in the specified selector and looks for input elements decorated with the [data-val=true] attribute value and enables validation according to the data-val-* attribute values.
Then you can hook ALL forms from a central place - just be aware all forms will be hooked. Instead of using $("#formId")
in the sample, simply use $("form").submit()
and that delegate will be called for any form's submit and in that method you can call your validate check and return true (to submit the form) or false to prevent it.
Something like this off the top of my head
$("form").submit(function () {
if (!$(this).valid()) {
return false;
}
else
{
return true;
}
});
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With