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

Slow Android emulator

I have a 2.67 GHz Celeron processor, 1.21 GB of RAM on a x86 Windows XP Professional machine. My understanding is that the Android emulator should start fairly quickly on such a machine, but for me it does not. I have followed all instructions in setting up the IDE, SDKs, JDKs and such and have had some success in staring the emulator quickly but is very particulary. How can I, if possible, fix this problem?

CCNA 1 Final Exam 2011 latest (hot hot hot)

  Hi! I have been posted content of ccna1 final exam (latest and only question.) I will post the answer and insert image on sunday. If you care, please subscribe your email an become a first person have full test content. Subcribe now  Some question  have not content because this question have images content. So that can you wait for me? SUNDAY 1. A user sees the command prompt: Router(config-if)# . What task can be performed at this mode? Reload the device. Perform basic tests. Configure individual interfaces. Configure individual terminal lines. 2. Refer to the exhibit. Host A attempts to establish a TCP/IP session with host C. During this attempt, a frame was captured with the source MAC address 0050.7320.D632 and the destination MAC address 0030.8517.44C4. The packet inside the captured frame has an IP source address 192.168.7.5, and the destination IP address is 192.168.219.24. At which point in the network was this packet captured? leaving host A leaving ATL leaving...