Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialdylan jasper
1,928 PointsColor does not persist when enclosing input inside a form tag
In this exercise we use an input tag to color the heading element. When used by itself the data captured in the input tag persists. However, if you enclose an input tag inside of a form tag (which is pretty standard) that data doesn't persist so the color flashes on the heading and then is gone. Without an action attribute assigned to the form data, I'm assuming the input is just gone forever. Is there a way to persist the data without using a backend language like php?
2 Answers
Steven Parker
231,271 PointsIf you use a "form" but forget to override the default submit behavior, the page will be reloaded which will cancel out any changes you have made to it.
If you want the page to reload, the only way to persist settings without back-end assistance is to save them in local storage and and re-apply them on load.
There happens to be a workshop here for Using Local Storage with JavaScript.
dylan jasper
1,928 PointsThank you for the explanation and the link to a workshop on the subject!
dylan jasper
1,928 PointsThank you for the response. Did you nest both the input and button elements inside the form tag? If you just nest the input you won't get the behavior I mentioned.
Steven Parker
231,271 PointsThat's because the button will not invoke the submit behavior (and cause a page reload) when it is outside of the form. When it is inside, you can override the submit behavior with a call to the "preventDefault" method of the event object.
Kieran Barker
15,028 PointsKieran Barker
15,028 PointsI don't understand what you mean. I just tried wrapping the
input
with aform
and it behaves exactly the same.