Skip to main content

Why is the form not preventing submission?



I have a basic form that I am using as a dummy to test some JavaScript functionality. My goal is to click the submit button and have submission paused until a javascript function is executed, then submit the form after that. the code I currently have is below, but the submission of the form is not prevented, and the hidden field's value is never set. can someone explain why this is happening?





NOTE I am aware of a jQuery method of performing the same functionality. I am specifically trying to solve this problem without using jQuery. If your only answer is "jQuery is better", please do not bother.







<html>

<head>

<script type="text/javascript">

function test(){

document.getElementById("hidden").value="hidden";



var queryString = $('#decisionform').formSerialize();

alert(queryString);



document.getElementById("form").submit();

}

</script>

</head>



<body>



<?php

if ($_POST){

foreach ($_POST as $key=>$value){

echo "<b>$key</b> $value<br>";

}

}

?>



<form action="hello.php" method="post" id="form">

<input name="first" type="text" />

<input name="second" type="text" />

<input name="third" type="text" />

<input name="hidden" type="hidden" />

<input name="submit" type="submit" value="Submit" onclick="test();return false;" />

</form>



</body>

</html>




Comments

  1. You don't have an element with the id hidden so document.getElementById("hidden").value="hidden"; will throw an error as you can't set properties on undefined. The script will stop running and never reach return false so the form will submit as normal.

    ReplyDelete
  2. try <form action="hello.php" method="post" id="form" onsubmit="test(); return false;">

    to prevent a submit, you actually need to have a return false, in the onsubmit even of the form itself

    along with not having an id on the hidden field.

    ReplyDelete
  3. <input name="submit" type="submit" value="Submit" onclick="test();return false;" />


    use a regular button in this case because your function is performing the submit.

    <input name="submit" type="button" value="Submit" onclick="test()" />

    ReplyDelete
  4. You're missing the id attribute from your input element. Modify <input name="hidden" type="hidden" /> to <input name="hidden" type="hidden" id="hidden" />.

    ReplyDelete
  5. You can use

    onclick="return test()"


    and just return false at the end of the function.

    ReplyDelete
  6. Add id="hidden" to your input, like this:

    <input name="hidden" type="hidden" id="hidden" />

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.