<img>
The <img>
tag is designed to display images on web pages. Each <img>
element must have the src
attribute and should contains the URL-address or the data URI of the image.
For example, you can display one-pixel red dot GIF as follows:
<img src="//static.base64.guru/uploads/images/1x1.gif" />
The same can be achieved by encoding image to Base64 and embedding it using data URI:
<img src="" />
Both behaviors are identical — when you open the page, your browser displays the same image specified within <img>
tag. The difference is that in the first case the browser sends one HTTP request to fetch the external image, when in the second case the image is already loaded in the browser’s memory and it does not need to send any HTTP requests.
It is important to note, that src
attribute will be ignored if it is a child of <picture> tag and at least one of its <source> tags match a requirement for the device screen or page layout.
Please note that Base64 Data URIs have some limitations. In addition, like almost any unconventional solutions, it has both advantages and disadvantages. Therefore, if you plan to use it, first of all, read about Base64 Data URI.
Comments (14)
I hope you enjoy this discussion. In any case, I ask you to join it.
html
<body>
...
<svg class="icon-1em-spec" viewBox="0 0 58 58">
<g id="icon_facebook"><title>[facebook]</title>
<path d="M54.8,0H3.2A3.2,3.2,0,0,0,0,3.2V54.8A3.2,3.2,0,0,0,3.2,58H31V35.6H23.5V26.8H31V20.3c0-7.5,4.6-11.5,11.3-11.5,2.2,0,4.5.1,6.7.3v7.8H44.4c-3.6,0-4.3,1.7-4.3,4.3v5.6h8.7l-1.2,8.8H40V58H54.8A3.2,3.2,0,0,0,58,54.8h0V3.2A3.2,3.2,0,0,0,54.8,0Z"></path></g>
</svg>
or define it and use it multiple times...
html
<body>
<svg style="display:none;" class="icon-1em-spec" viewBox="0 0 58 58">
<defs>
<g id="icon_facebook"><title>[facebook]</title>
<path d="M54.8,0H3.2A3.2,3.2,0,0,0,0,3.2V54.8A3.2,3.2,0,0,0,3.2,58H31V35.6H23.5V26.8H31V20.3c0-7.5,4.6-11.5,11.3-11.5,2.2,0,4.5.1,6.7.3v7.8H44.4c-3.6,0-4.3,1.7-4.3,4.3v5.6h8.7l-1.2,8.8H40V58H54.8A3.2,3.2,0,0,0,58,54.8h0V3.2A3.2,3.2,0,0,0,54.8,0Z"></path></g>
</defs>
</svg>
...
<svg class="icon-1em-spec" viewBox="0 0 58 58">
<use xlink:href="#icon_facebook"></use>
</svg>
That would be as such:

although, there is another method:
leave out the ";base64" and it'll be assumed, that the following data is URL-encoded like such:
data:image/svg+xml,%3Csvg%20viewBox%3D%220%200%20100%20250%22%3E%3ClinearGradient%20id%3D%22a%22%20x1%3D%2250%22%20x2%3D%2250%22%20y1%3D%220%22%20y2%3D%22250%22%20gradientUnits%3D%22userSpaceOnUse%22%3E%3Cstop%20offset%3D%220%22%20stop-color%3D%22%23f69%22%2F%3E%3Cstop%20offset%3D%221%22%20stop-color%3D%22%23808%22%20stop-opacity%3D%22.5%22%2F%3E%3C%2FlinearGradient%3E%3Cpath%20fill%3D%22url(%23a)%22%20stroke%3D%22%23000%22%20d%3D%22M50%2050v50l50%2050v50l-50%2050-50-50v-50l25-25m25%2075v-50L0%20100V50L50%200l50%2050v50l-25%2025%22%2F%3E%3C%2Fsvg%3E