Conception web – Forcer le cache à se vider pour vos fichiers CSS, JS et vos images
Toujours dans un but de poster des petites astuces et de répondre aux questions de mes collègues, amis ou clients, voici un petit billet pour vous expliquer quelques pratiques pour forcer le cache navigateur à re-télécharger certains éléments de votre site qui ont changé, mais qui restent en cache navigateur, car le nom du fichier, lui, est toujours le même.
En effet, le navigateur garde en mémoire certains éléments (css, images, javascript etc…) afin d’améliorer la vitesse de chargement. Mais il arrive que de petites modifications ne soient pas prises en compte ce qui peut perturber l’affichage et/ou la navigation des internautes sur votre site. Bien entendu, en tant que développeur, vous savez qu’il faut vider le cache navigateur, mais certains visiteurs (et surtout vos clients) ne le savent pas forcément. Alors, il existe quelques astuces pour essayer de palier à ce soucis.
Renommer les fichiers
Bien entendu, il vous est possible de renommer tous les fichiers qui ont été modifiés, mais ça peut s’avérer fastidieux, surtout si vous apportez souvent de petites modifications.
Utilisation des requêtes via le ?
Déjà plus pratique, il vous est possible d’utiliser lors de l’appel du ou des fichiers une requête « factice » après le point interrogation « ? ».
Comme ceci par exemple :
[pastacode lang= »markup » manual= »%3Clink%20href%3D%22css%2Fstyle.css%3F1234%22%20type%3D%22text%2Fcss%22%20rel%3D%22stylesheet%22%20%2F%3E » message= » » highlight= » » provider= »manual »/]
Et donc modifier juste l’appel à chaque modification, « 1234 » deviendra « 12345 » etc…
Si vous utilisez PHP, nous pouvons améliorer ce petit procédé et le rendre automatique, exemple simple :
[pastacode lang= »php » manual= »%3Clink%20href%3D%22css%2Fstyle.css%3F%3C%3Fphp%20echo%20time()%3B%20%3F%3E%22%20type%3D%22text%2Fcss%22%20rel%3D%22stylesheet%22%20%2F%3E » message= » » highlight= » » provider= »manual »/]
Ce qui le modifiera à chaque fois et le navigateur le téléchargera à chaque fois.
Cependant, il est possible d’améliorer cela, éviter ainsi le téléchargement systématique du fichier, et faire en sorte que ce dernier ne soit téléchargé uniquement si le fichier à été modifié, exemple :
[pastacode lang= »php » manual= »%3Clink%20href%3D%22css%2Fstyle.css%3F%3C%3Fphp%20echo%20filemtime(‘css%2Fstyle.css’)%3B%22%20type%3D%22text%2Fcss%22%20rel%3D%22stylesheet%22%20%2F%3E » message= » » highlight= » » provider= »manual »/]
Petite astuce simple à mettre en place et qui peut s’avérer utile dans certains cas 😉
Bon code à tous !
Articles qui peuvent vous intéresser :
14 décembre 2011
Merci pour les codes Javascript, très apprécié!
23 juillet 2012
Merci pour l’astuce, souvent ennuyé avec le cache.
Je galère à expliquer aux clients que leur cache doit être vidé, il me disent « pourquoi mes modifs ne sont pas prises en compte »
23 juillet 2012
Un problème récurent pour tous les spécialistes du web 🙂 en tout cas, ça peut toujours servir 😉