Monday, June 3, 2024
 Popular · Latest · Hot · Upcoming
67
rated 0 times [  74] [ 7]  / answers: 1 / hits: 47087  / 10 Years ago, wed, december 3, 2014, 12:00:00

I'm trying to store via local storage all form field values (under the input id) like so localStorage.setItem(input id, fieldvalue); when a user clicks the save button. the reason being is so at a later date the user has the option of reloading the form field values instead of retyping everything the problem is the input id and name fields are not known because they are generated depending on what the user selects in the previous page (what template they choose).



Demo (let's say this was generated):



<input type=text id=meta_title name=seo_meta_title> 
<input type=text id=meta_description name=seo_meta_description>
<input type=text id=header name=header>

<!-- Submit form-->
<input type=submit value=Create>

<!-- buttons-->
<button onclick=save()>save</button>
<button onclick=load()>load</button>


because I don't know the input ids, I can't just write:



function save() {
if (typeof(Storage) != undefined) {

//some_code_to_insert_value = x, y, z

localStorage.setItem(meta_title, x);
localStorage.setItem(meta_description, y);
localStorage.setItem(header, z);
}
}


And same goes for the load function



// LOAD
function load() {
if (typeof(Storage) != undefined) {
// Adds data back into form fields

document.getElementById(meta_title).value = localStorage.getItem(meta_title);
document.getElementById(meta_description).value = localStorage.getItem(meta_description);
document.getElementById(header).value = localStorage.getItem(header);

}
}


I'm very new to JavaScript as I'm sure you can tell any help, code or links would be much appreciated and a working js fiddle would be beyond amazing (as long as it doesn't rely on pre-knowing the input id etc..) I have spent a few hours trying to do this and wasted even more time trying to generate the JS needed with PHP in till I was told this was a terrible way to do it.


More From » php

 Answers
15

If you want to rely on jQuery this can help you:



$('#save').on('click', function(){

$('input[type=text]').each(function(){
var id = $(this).attr('id');
var value = $(this).val();
localStorage.setItem(id, value);

});
});

$('#load').on('click', function(){
$('input[type=text]').each(function(){
var id = $(this).attr('id');
var value = localStorage.getItem(id);

$(this).val(value);

});
});


I would recommend to avoid inline-js, so I updated to code to use .on() for attaching the click-handler to the two buttons.



Demo



Reference:



.each()


[#68599] Tuesday, December 2, 2014, 10 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
skyler

Total Points: 646
Total Questions: 119
Total Answers: 96

Location: Bonaire
Member since Wed, Mar 29, 2023
1 Year ago
skyler questions
;