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:
- or any resource.
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
- charset is a Text - Encoding (Character Set|charset|code page)
- data is the data encoded in the character set in base64 or not
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:
- Plain text base64 encoded
<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:
- Create the blob data container with plain text
let textBlob = new Blob( ["Hello World !"], { type: 'text/plain' });
- Create the objectUrl
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: