The Question :
398 people think this question is useful
I have a form. Outside that form, I have a button. A simple button, like this:
Nevertheless, when I click it, it submits the form. Here’s the code:
<button onclick="document.getElementById('myform').doNotSubmit();">My Button</button>
The Question Comments :
The Answer 1
946 people think this answer is useful
I think this is the most annoying little peculiarity of HTML… That button needs to be of type “button” in order to not submit.
<button type="button">My Button</button>
Update 5-Feb-2019: As per the HTML Living Standard (and also HTML 5 specification):
The missing value default and invalid value default are the Submit
The Answer 2
38 people think this answer is useful
return false; at the end of the onclick handler will do the job. However, it’s be better to simply add
type="button" to the
The Answer 3
17 people think this answer is useful
By default, html buttons submit a form.
This is due to the fact that even buttons located outside of a form act as submitters (see the W3Schools website: http://www.w3schools.com/tags/att_button_form.asp)
In other words, the button type is “submit” by default
<button type="submit">Button Text</button>
Therefore an easy way to get around this is to use the button type.
<button type="button">Button Text</button>
Other options include returning false at the end of the onclick or any other handler for when the button is clicked, or to using an < input> tag instead
To find out more, check out the Mozilla Developer Network’s information on buttons: https://developer.mozilla.org/en/docs/Web/HTML/Element/button
The Answer 4
15 people think this answer is useful
Dave Markle is correct. From W3School’s website:
Always specify the type attribute for
the button. The default type for
Internet Explorer is “button”, while
in other browsers (and in the W3C
specification) it is “submit”.
In other words, the browser you’re using is following W3C’s specification.
The Answer 5
2 people think this answer is useful
It’s recommended not to use the
<Button> tag. Use the
<Input type='Button' onclick='return false;'> tag instead. (Using the “return false” should indeed not send the form.)
Some reference material
The Answer 6
1 people think this answer is useful
For accessibility reason, I could not pull it off with multiple
type=submit buttons. The only way to work natively with a
form with multiple buttons but ONLY one can submit the form when hitting the
Enter key is to ensure that only one of them is of
type=submit while others are in other type such as
type=button. By this way, you can benefit from the better user experience in dealing with a form on a browser in terms of keyboard support.
The Answer 7
0 people think this answer is useful
Another option that worked for me was to add onsubmit=”return false;” to the form tag.
<form onsubmit="return false;">
Semantically probably not as good a solution as the above methods of changing the button type, but seems to be an option if you just want a form element the won’t submit.