2

Learning how to utilize Bootstrap, I noticed that the thumbnails had strange markup for the image source (at least, strange to me.)

<img data-src="holder.js/260x120" alt="260x120" style="width: 260px; height: 120px;" src="">

What's going on here, and why is this being done? Is the image somehow saved to local storage at some point in base64?

To clarify, I'm asking about the src="image:/ part.

Ashley Ross
  • 2,345
  • 2
  • 23
  • 43
Cody
  • 8,686
  • 18
  • 71
  • 126
  • as far as I am aware: attributes prefixed with "data" are allowed. Lets you do things like save the thumbnail src for that image on the image element, for ease of operations later. – Colleen Jan 04 '13 at 23:12
  • http://stackoverflow.com/questions/2450585/why-should-i-prepend-my-custom-attributes-with-data – Colleen Jan 04 '13 at 23:13
  • I know what the data attribute does, but I don't know how the image is being saved and embedded in that data attribute. – Cody Jan 04 '13 at 23:22
  • 3
    This: http://www.ietf.org/rfc/rfc2397.txt, wiki article: http://en.wikipedia.org/wiki/Data_URI_scheme – Šime Vidas Jan 04 '13 at 23:23
  • 2
    @DoctorOreo You're confusing HTML5 `data-` attributes, with the `data:` URI scheme. Those are two completely different things. – Šime Vidas Jan 04 '13 at 23:26
  • Edit: OH, you're talking about something else. I know nothing about the data:URI scheme. – Colleen Jan 04 '13 at 23:26

2 Answers2

5

What you are seeing is not the HTML5 data- attribute, but the data URI scheme. To quote Wikipedia:

The data URI scheme ... provides a way to include data in-line in web pages as if they were external resources. This technique allows normally separate elements such as images and style sheets to be fetched in a single HTTP request rather than multiple HTTP requests, which can be more efficient.

What you're seeing is the base64-encoded image data, in this case a PNG. When browsers see this, they decode the data as instructed, and display it as if it were an external resource.

Given this image's size, the creators of Bootstrap rightly believe it is more efficient to inline the image like this rather than keeping it separate. Had they kept it separate, it would require an additional HTTP request to load the image, which increases the total load time of the page.

Ashley Ross
  • 2,345
  • 2
  • 23
  • 43
0

In the case of Bootstrap, what I think you are seeing is Javascript being used to generate the data that goes in the src attribute.

If you look at the raw source (not the source in the inspector), you will probably not see the src attribute, only data-src.

The data-src attribute is an instruction to javascript to use the holder.js script to generate the data to go in the src.

So holder.js generates the image, which is then loaded into the img as a data uri as explained by the other answers.

ChrisJ
  • 2,486
  • 21
  • 40