Disable Submit Button Upon Form Submission
Multiple clicks on a "Submit" button can cause duplicate processing if your programming is slow or the user's connection is lagging. Duplicate processing can include duplicate database records, multiple emails, or different types of errors. JavaScript provides an easy way to disable the multiple submission of a form once the form has been submitted.
The Code
In the HTML, use the following "onsubmit" information:
It's important to trigger the even on form submission -- not everyone clicks the "submit" button. You will also need to give your submit button the submit_button ID attribute.
![Regular Expressions for the Rest of Us]()
Sooner or later you'll run across a regular expression. With their cryptic syntax, confusing documentation and massive learning curve, most developers settle for copying and pasting them from StackOverflow and hoping they work. But what if you could decode regular expressions and harness their power? In...
![How I Stopped WordPress Comment Spam]()
I love almost every part of being a tech blogger: learning, preaching, bantering, researching. The one part about blogging that I absolutely loathe: dealing with SPAM comments. For the past two years, my blog has registered 8,000+ SPAM comments per day. PER DAY. Bloating my database...
![Introducing LazyLoad 2.0]()
While improvements in browsers means more cool APIs for us to play with, it also means we need to maintain existing code. With Firefox 4's release came news that my MooTools LazyLoad plugin was not intercepting image loading -- the images were loading regardless of...
![Using Opacity to Show Focus with MooTools]()
I'm a huge fan of using subtle effects like link nudging (jQuery, MooTools) to enhance the user experience and increase the perceived dynamism of my websites. Trust me -- a lot of little things are what take websites to the next level.
As an aside, if you’re also using any javascript validation, disable the submit button only after you’ve passed the validation tests.
Also, if the form is output programattically and the results stored in a DB, you can incorporated a unique hidden value in the form and redirect to an error page on duplicate submission detection.
Great tips (and name) Dave!
I’ve never been a fan of “disabling” elements on a website, but if it can save a developer lots of cleanup in the long run, I say do it.
How would you write a code to “redirect to an error page on duplicate submission detection.”
oh, and my middle name is David. It may not be Dave but it is pretty close. :D
thanks for the tip… might also be a good idea to apply some sort of visual display so your users know the server is working. :)
Hi David,
I’m having a really hard time trying to disable a submit (IMAGE) button when the page is submitted in APEX 3.2.
I cannot get the SUBMIT button to disable itself. Somehow this only works on HTML Buttons rather than IMAGES from CSS Templates.
Would appreciate it if you could suggest an alternative.
Thanks.
Great way of prevention. Thanks a lot. I just implemented it on one of my websites.
Does anyone have a unit test code for testing the submit button disabled when click it?
Thank boss..u saved my time
i can’t disable the submit button because i have some validation before page submit.if the validation failed the button is permanently disabled please some one assist