Table of Contents

About

The data scheme is a scheme that can be used in a URL in order to embed (small) media resources data directly such as:

The benefit is that there is no need for extra HTTP requests in order to fetch the resource, making the page load more efficient.

As for all performance optimizations, there is a trade off between growing the size of your page by inlining all resources and fetching asynchronously the resources. Generally, the inlined media resources are of small size (ie <2kb)

Syntax

data:[<MIME-type>][;charset=<encoding>][;base64],<data>

where

Note that you can create data URL programmatically with the URL.createObjectURL function. See the example below

Example

Jpeg - Base 64

The HTML fragment could be used for a small inline image in a HTML document. (The embedded image is probably near the limit of utility. For anything else larger, data URLs are likely to be inappropriate.)

Image in What is Base64? (Cryptography Cipher)

<img src=""
ALT="Nico">

Svg

The svg is used in an URL and should then be url encoded. (You can grab a background css directly via this codepen)

.navbar-toggler-icon {
   background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' viewBox='0 0 17 17'%3E%3Cg%3E%3C/g%3E%3Cpath d='M17 16v1h-17v-1h17zM12 10h2v5h1v-6h-4v6h1v-5zM7 7h2v8h1v-9h-4v9h1v-8zM2 3h2v12h1v-13h-4v13h1v-12z' /%3E%3C/svg%3E");
}

.navbar-toggler-icon {
    display: inline-block;
    width: 3em;
    height: 3em;
    vertical-align: middle;
    content: "";
    background-size: 100% 100%;
}
<span class="navbar-toggler-icon"></span>

Plain Text to download

Example with the anchor download attribute

  • Plain text
<a href="data:text/plain,Hello World" download="hello-world.txt">Download hello-world.txt</a>
  • Result:
<a href="data:text/plain;base64,SGVsbG8gV29ybGQgIQ==" download="hello-world.txt">Download base64 encoded hello-world.txt</a>

How to create data url with the URL.createObjectURL

The javascript browser api function URL.createObjectURL permits to create data uri programmatically directly. You don't need to form a data url or transform the payload in base64

Example: The same example than above to download a text file can rewritten:

let textBlob = new Blob( ["Hello World !"], { type: 'text/plain' });
let objectUrl = URL.createObjectURL(textBlob);
  • Create the anchor with its attribute
let a = document.createElement("a");
document.body.append(a);
a.href=objectUrl;
let fileName = "hello-world.txt";
a.setAttribute("download",fileName);
a.innerText = `Download ${fileName}`;
// To prevent memory leaks, always revoke the URL after the download.
a.addEventListener('click', (e) => {
    setTimeout(() => URL.revokeObjectURL(e.target.href), 30 * 1000);
});
  • Result:

Documentation / Reference