I have a problem with my SessionStorage. I stored all my items in a specific order, but when I try to get them back (with a for
loop), they are not in the correct order.
Here is how I set my SessionStorage:
function set_Item(){
var nom = document.getElementById("nom").value;
nom = nom.toUpperCase();
sessionStorage.setItem("Nom", nom);
sessionStorage.setItem("Prenom", document.getElementById("prnm").value);
sessionStorage.setItem("Adr", document.getElementById("adr").value);
sessionStorage.setItem("cdPost", document.getElementById("cdPost").value);
sessionStorage.setItem("Ville", document.getElementById("ville").value);
sessionStorage.setItem("Pays", document.getElementById("pays").value);
}
And this is how I get back my elements:
function get_Item(){
var res = document.getElementById("res");
var txt;
var key;
var valeur;
for(var i = 0; i< sessionStorage.length; i++){
key = sessionStorage.key(i);
valeur = sessionStorage.getItem(key);
if(key == "Nom"){
txt = document.createElement("p");
txt.textContent = valeur + " " + sessionStorage.getItem(sessionStorage.key(i+1));
res.insertAdjacentElement('beforeend',txt);
i++;
}else {
txt = document.createElement("p");
txt.textContent = valeur + " ";
res.insertAdjacentElement('beforeend',txt);
}
}
}
What I get:
The order of the items is random and it sometimes changes.
I know that I can use the key to get the right items and set the good rendering order. But what's the reason for this behaviour?