Published on April 3, 2024 · 5 min read
Working with Data URIs and Base64
Learn how to embed images and files in HTML/CSS using Base64 encoded Data URIs.
What are Data URIs?
Data URIs (or data URLs) allow you to embed small files directly into HTML or CSS as base64-encoded strings. They begin with 'data:' followed by an optional MIME type, and the base64-encoded data. This eliminates the need for separate HTTP requests for small resources.
// Data URI Structure data:[<media type>][;base64],<data> // Example ...
Common Use Cases
- Small images in HTML/CSS (icons, logos)
- Custom fonts using @font-face
- SVG images in CSS backgrounds
- Small audio files for web applications
- Embedding PDF files inline
Converting Files to Data URIs
Here's how to convert files to Data URIs in JavaScript:
// Using FileReader const fileInput = document.querySelector('input[type="file"]'); const file = fileInput.files[0]; const reader = new FileReader(); reader.onload = function(e) { const dataUri = e.target.result; console.log(dataUri); // ... }; reader.readAsDataURL(file); // For images in HTML <img src="..." alt="Icon" /> // For backgrounds in CSS .icon { background-image: url('...'); }
MIME Types and Base64
Common MIME types for Data URIs:
// Images image/png image/jpeg image/gif image/svg+xml // Fonts font/woff font/woff2 font/ttf // Documents application/pdf text/plain text/html // Audio audio/mpeg audio/wav
Best Practices and Considerations
- Only use for small files (ideally under 5KB)
- Consider caching implications (Data URIs can't be cached separately)
- Base64 encoding increases file size by ~33%
- Use for critical above-the-fold images
- Consider performance impact on mobile devices
- Test browser compatibility for specific use cases
Performance Tips
Selective Usage
Only use Data URIs for small, frequently used resources
Image Optimization
Optimize images before converting to Base64
Caching Strategy
Consider implementing local storage caching for Data URIs
Loading Performance
Balance between Data URIs and traditional resource loading