Blank image encoded as data-uri

HtmlWeb StandardsData Uri

Html Problem Overview


I've built an image slider (based on the terrific bxSlider) which will preload images just-in-time before they slide into view. It's working pretty well already, but I don't think my solution is valid HTML.

My technique is as follows: I generate the slider markup with the first slide image being inserted as usual (with an <img src="foo.jpg">) and subsequent images being referenced in a data attribute like <img data-orig="bar.jpg">. A Javascript then juggles the data-orig -> src change when necessary, triggering the preloading.

In other words, I have:

<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>

To avoid empty src="" attributes (which are harmful to performance in some browsers), I've inserted src="data:" to effectively insert a blank image as a placeholder.

The thing is, I can't seem to find anything in the documentation for data-URI saying whether this is a valid data-URI or not. I basically want the minimal data-URI that resolves to a blank/transparent image, so the browser can resolve the src immediately and move on (with no error or network request). Maybe src="data:image/gif;base64," would be better?

Html Solutions


Solution 1 - Html

I looked into it and the smallest possible transparent GIF image, encoded as a data-uri, was this:



which is what I'm using now.

Solution 2 - Html

If you need a transparent image 1x1 pixel, just set this data uri as src default attribute (keep the /// parts, it encodes byte 255, not a comment).



This is instead a base64 encoding for an image 1x1 white.



Otherwise you could set data:null and save ~60 extra bytes for each image.

Solution 3 - Html

The smallest I've ever seen



update: This seems broken and doesn't work anymore as reported by @bryc, please use the other answers.

Solution 4 - Html



is smaller :D

Solution 6 - Html

1px by 1px JPEG image



Solution 7 - Html

Fabrizio's "white gif" isn't actually perfectly white : it is rgb(254, 255, 255).

I use the following one (which happens to be smaller), found on this page.



Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionJens RolandView Question on Stackoverflow
Solution 1 - HtmlJens RolandView Answer on Stackoverflow
Solution 2 - HtmlFabrizio CalderanView Answer on Stackoverflow
Solution 3 - HtmlazerafatiView Answer on Stackoverflow
Solution 4 - HtmlAdriaView Answer on Stackoverflow
Solution 5 - HtmlAlexView Answer on Stackoverflow
Solution 6 - HtmlMatt Votsikas McLeanView Answer on Stackoverflow
Solution 7 - HtmlMaël NisonView Answer on Stackoverflow