My onsubmit
is not working. My idea was to put some mandatory fields and, in order to achieve that, I was using the onsubmit
method inside a form in HTML that called a JavaScript function.
The idea was if all the mandatory fields were filled, the javascript function would return true
and it would move on to page /control/Cadastro.php
. Otherwise, if any mandatory field was empty, it would return false
and it wouldn't move to page /control/Cadastro.php
, staying in the current page until true.
Unfortunately, the function does return false
if all the mandatory fields are not filled, as expected, but it still moves to page /control/Cadastro.php
, even if it shouldn't.
I'm going to cut off some code to make my point of view perceptible.
<!DOCTYPE html>
<html>
<head>
<script>
function ValidateRequiredFields()
{
var message = new String('\nCampos obrigatórios:\n');
var flag=new Boolean(1);
var x=document.forms["theForm"]["nr_processoCA"].value;
if (x==null || x==""){
message += '\nNº do processo\n';
flag = new Boolean(0);
}
if (flag == false){
alert(message);
}
return flag;
}
</script>
</head>
<body>
<form name="theForm" onsubmit="return ValidateRequiredFields()" method="post" action="../control/Cadastro.php">
Nº do Processo: <br>
<input type="text" name="nr_processoCA" class="input-xlarge">
<br>
<div class="row-fluid" style="text-align:center;">
<input type="submit" class="btn btn-primary btn-large" value="Gravar">
</div>
</form>
</body>
</html>
To make this work, your
ValidateRequiredFields
function needs to return a boolean value. And then you should attach that method to theonSubmit
event. Remember, that foronsubmit
you need to use thereturn
keyword.This code sample works:
I was having a similar problem. It turned out there was an error in my validation (nested a few functions deep) which was causing JavaScript to quit execution of the function before reaching a return statement. At which point it would just continue with the submit.
My advise to anyone finding this page looking for an answer to "onsubmit method doesn't stop submit" is to step through your validation function with a fine tooth comb.
i suggest to put a button that will run the form if true:
that's all....
You should use
preventDefault
inside your onsubmit function. I modified your code:DEMO
An object will always evaluate to true, even if it's a Boolean object with value false.
Put
flag = true
at the top of the function, thenflag = false
instead of creating a Boolean.After looking around for an answer that worked for me I decided to just create a solution. The following code allows native HTML5 form validation to run before submitting or running another function (tested in Chrome). Make sure you return false after the function to prevent the form submission.