I have a long form that I've broken up into 6 steps. When the form is loaded, all of the steps are loaded, but only the first step is visible. The rest have CSS of
display:none and the new step is set to
display:block. On the final step, the user submits the form. However, as expected, only the fields in
display:block element on the page are submitted. All the completed fields in the elements with
display:none are ignored.
Is there a way to submit the fields inside the
If not, is there another way to achieve the same effect?
Set them to
position:absolute instead. The fields will not be sent to the server with
display:none, but will be with
visibility:hidden. By also toggling "position" to "absolute" you should get the same visual effect.
Update This does not appear to be an issue anymore in any current browser (as of Nov of 2015). Fields are submitted even if display is set to 'none'. Fields that are 'disabled', however, will continue to not be submitted.
The HTML4, section 17.13.2, says explicitly that even hidden controls using display:none may be valid for submission.
So if the browser ignores display:none then it is not fully HTML-capable. I recommend switching for a real browser.
©2020 All rights reserved.