IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Comprendre le storage en HTML5

La fonctionnalité storage est une nouveauté HTML5, ce procédé va permettre de simplifier le processus de sauvegarde et de persistance des données.

Cette fonctionnalité est similaire au cookie de session HTTP et permet de sauvegarder les données voulues dans une « base de données » côté client (c'est-à-dire au niveau du navigateur).

Si vous voulez voir le contenu de sessionStorage et localStorage, avec Chrome, c'est très facile via les « outils de développement », onglet "Storage" :

Visualiser le sessionStorage et le localStorage

4 commentaires Donner une note à l´article (5) ?

Article lu   fois.

L'auteur

Profil ProSite personnel

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

I. Compatibilité

Chrome, Safari, Opera, Firefox 4, Internet Explorer 8 et 9.

II. Intérêt du storage

  • On peut enregistrer des données même quand la connexion Internet est coupée (le storage étant dans le navigateur).
  • On peut gérer des données par session (si vous avez 2 fenêtres sur le même site, une action sur le sessionStorage sera répercutée sur l'autre).
  • On peut gérer des données par page (localStorage).

Le storage a pour but de répondre à une des limites des cookies, c'est-à-dire leur taille (4 ko pour les cookies et jusqu'à 10Mo pour le storage!).

Nous allons donc voir à travers des exemples le localStorage et le sessionStorage via l'API storage en HTML5.

III. L'API storage

Chaque objet storage permet d'accéder à une liste de clés/valeurs (items). Les clés sont des string (la clé peut être vide).

Attribut

length : retourne le nombre de paires clé/valeur.

Méthode

key(n) : retourne la clé à l'index n, retourne NULL s’il n'y a pas de résultat.

getItem(key) : retourne la valeur de la clé key.
Il est à noter que le storage est un tableau, on peut accéder aux données de cette manière :

Exemple :

 
Sélectionnez
    alert(window.sessionStorage['cle']);

setItem(key, value) : ajoute une paire clé/valeur.
Il est à noter que le storage est un tableau, on peut donc attribuer une paire clé/valeur de cette façon :

Exemple :

 
Sélectionnez
    window.sessionStorage['cle'] = 'ma valeur';

Si la clé existe déjà, la valeur sera mise à jour.
Le setItem peut retourner une exception :

  • NOT_SUPPORTED_ERR : la valeur n'est pas supportée ;
  • QUOTA_EXCEEDED_ERR : il n'y a plus de place pour mémoriser d'autres valeurs ou alors l'utilisateur a désactivé le storage.

En cas d'échec et donc d'exception la paire clé/valeur ne sera pas créée ni mise à jour (si elle était existante).

removeItem(key) : supprime la paire clé/valeur dont la clé est key. Si la clé n'existe pas, rien n'est effacé.

Clear() : vide toutes les paires clé/valeur, s'il y en a.

IV. sessionStorage

Commençons par un exemple :

 
Sélectionnez
    if(window.sessionStorage){
        window.sessionStorage.setItem('cle1', 'une valeur');
        /*Autre manière de le faire*/
        window.sessionStorage['cle2'] = 'ma valeur';
    }else{
        $('.testSession').html('le sessionStorage n\'est pas implémenté sur ce navigateur');
    }

On ajoute deux paires de clé/valeur dans le sessionStorage. Voici le résultat sous chrome :

clés dans le sessionStorage

Démo

Maintenant, voyons le removeItem.

Tout d'abord, affichez toutes les données et ensuite effacez-en une, puis réaffichez toutes les données : Démo.

Le résultat du removeItem est visible dans l'onglet Storage des outils développeurs de Chrome :

résultat du removeItem()

V. localStorage

le localStorage fonctionne de la même manière que le sessionStorage :

 
Sélectionnez
    window.localStorage.getItem('key');
    window.localStorage.setItem('key', 'value');
    window.localStorage.removeItem('key');
    window.localStorage.length;
    window.localStorage.key(n);

Exemple :

 
Sélectionnez
    if(window.localStorage){
        window.localStorage.setItem('cle1', Math.random());
    }

VI. La différence entre localStorage et sessionStorage

La différence entre les deux se trouve dans la durée de stockage des données. sessionStorage persiste le temps d'une session de navigation. Ouvrir une nouvelle fenêtre ou un nouvel onglet, initialisera donc un nouvel objet. On pourrait donc utiliser sessionStorage pour un formulaire multipage, et conserver de l'information d'une page à l'autre. localStorage, quant à lui, conserve les données pour une durée indéterminée. On accède uniquement aux paires clé/valeur d'un même domaine.

VII. Compléments d'information

Chaque navigateur offre 5 Mo de stockage et 10 Mo pour Internet Explorer 8.

Sous Firefox, on peut accéder au stockage de mémoire en tapant l'instruction suivante dans la barre d'adresse :

 
Sélectionnez
about:memory

Il existe des librairies JavaScript qui peuvent se charger du stockage. Exemple :

  • http://developer.yahoo.com/yui/storage/;
  • http://yuilibrary.com/gallery/show/storage-lite.

VIII. Remerciements

Merci à jpvincent pour ses compléments d'information.

Merci à eusebe19 pour sa relecture.

4 commentaires Donner une note à l´article (5)

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+   

Copyright © 2020 debray jerome. Aucune reproduction, même partielle, ne peut être faite de ce site ni de l'ensemble de son contenu : textes, documents, images, etc. sans l'autorisation expresse de l'auteur. Sinon vous encourez selon la loi jusqu'à trois ans de prison et jusqu'à 300 000 € de dommages et intérêts.