J'ai construit un curseur d'image (basé sur le formidable bxSlider ) qui précharge les images juste à temps avant qu'elles ne glissent dans la vue. Cela fonctionne déjà plutôt bien, mais je ne pense pas que ma solution est un code HTML valide.
Ma technique est la suivante: je génère le balisage du curseur avec la première image de la diapositive insérée comme d'habitude (avec un <img src="foo.jpg">
) et les images suivantes référencées dans un attribut de données comme <img data-orig="bar.jpg">
. Un Javascript jongle alors le data-orig -> src
changez si nécessaire en déclenchant le préchargement.
En d'autres termes, j'ai:
<div class="slider">
<div><img src="time.jpg" /></div>
<div><img src="data:" data-orig="fastelavn.jpg" /></div>
<div><img src="data:" data-orig="pels_strik.jpg" /></div>
<div><img src="data:" data-orig="fashion.jpg" /></div>
</div>
Pour éviter les vides src=""
attributs (qui sont nuisibles à la performance dans certains navigateurs ), J'ai inséré src="data:"
pour insérer efficacement une image vierge en tant qu’espace réservé.
Le problème est que je n'arrive pas à trouver quoi que ce soit dans la documentation relative à l'URI de données indiquant s'il s'agit d'un identifiant de données valide ou non. Je veux fondamentalement l'URI de données minimal qui résout une image vide/transparente, afin que le navigateur puisse résoudre le problème immédiatement et continuer (sans erreur ni demande réseau). Peut être src="data:image/gif;base64,"
serait mieux?
J'ai regardé et la la plus petite image GIF transparente possible , encodée en tant que data-uri, était la suivante:

c'est ce que j'utilise maintenant.
si vous avez besoin d'une image transparente 1x1 pixel, définissez cette donnée comme uri avec l'attribut src
default

c'est à la place un encodage base64 pour une image 1x1 blanche

sinon vous pouvez définir data:null
et économisez environ 60 octets supplémentaires pour chaque image
données: image/gif; base64, R0lGODlhAQABAAAAACw =

est plus petit: D
Image JPEG 1px par 1px

Le "gif blanc" de Fabrizio n'est pas réellement parfaitement blanc: c'est rgb(254, 255, 255)
.
J'utilise le suivant (qui se trouve être plus petit), trouvé sur cette page .
