Reducing Web Requests Using DATA URI Scheme (Alternative to CDN?)

PerformanceHTML5JavaScriptCloudDrupal

How to use the DATA URI scheme to embed images directly in your HTML/CSS and reduce HTTP requests

Reducing Web Requests Using DATA URI Scheme (Alternative to CDN?)

To decrease the loading time for web pages, we adopt different methods. One of the most effective is reducing the number of HTTP requests. This is why many developers use CSS Sprites for situations where you have multiple small images used as backgrounds for HTML elements.

But CSS Sprites only work when using images as backgrounds. What about images that need to be displayed with image tags? Traditionally, we'd look to Content Delivery Networks (CDNs) for optimization. However, there's another approach worth considering: DATA URI scheme.

What is DATA URI?

The DATA URI scheme allows you to embed small files directly into your HTML or CSS as a base64 encoded string. Instead of linking to an external resource, you include the actual content inline.

<!-- Traditional image tag -->
<img src="small-icon.png" alt="Icon">

<!-- Same image using DATA URI -->
<img src="" alt="Icon">

Advantages of DATA URI

  1. Reduced HTTP requests: Each HTTP request has overhead in terms of DNS lookup, TCP connection establishment, and HTTP headers. DATA URIs eliminate these requests.

  2. Immediate availability: The browser doesn't need to make a separate request to fetch the resource - it's already there in the HTML/CSS.

  3. Caching benefits: When you include DATA URIs in your CSS files, they get cached along with the CSS.

  4. Parallel download limit bypass: Browsers limit the number of concurrent connections to a domain, but DATA URIs don't count toward this limit.

Implementation in Practice

Here's how to convert an image to a DATA URI:

// Using JavaScript to convert an image to DATA URI
function getDataURI(img) {
  // Create canvas element
  var canvas = document.createElement('canvas');
  canvas.width = img.width;
  canvas.height = img.height;
  
  // Draw image on canvas
  var ctx = canvas.getContext('2d');
  ctx.drawImage(img, 0, 0);
  
  // Get DATA URI
  return canvas.toDataURL('image/png'); // Or 'image/jpeg' for JPG images
}

// Usage
var img = new Image();
img.onload = function() {
  var dataURI = getDataURI(this);
  console.log(dataURI); // Use this URI in your HTML/CSS
};
img.src = 'small-icon.png';

For server-side conversion, many languages have libraries to handle this. For example, in PHP:

// PHP function to convert image to DATA URI
function imageToDataURI($imagePath) {
  $mime = mime_content_type($imagePath);
  $data = base64_encode(file_get_contents($imagePath));
  return 'data:' . $mime . ';base64,' . $data;
}

Considerations and Limitations

While DATA URIs offer advantages, they have limitations:

  1. Base64 overhead: Base64 encoding increases the file size by approximately 33%.

  2. Browser support: While modern browsers support DATA URIs well, IE7 and below have significant limitations.

  3. Caching granularity: Individual images can't be cached separately - they're part of the containing document.

  4. Parsing overhead: Browsers may take longer to parse large DATA URIs.

  5. File size: DATA URIs are most effective for small images (typically under 5KB).

Best Practices

  • Use DATA URIs for small, frequently used images
  • Implement them in your CSS rather than inline HTML where possible
  • Consider using sprites for larger collections of images
  • Test performance in your specific use case

Comparison with CDNs

DATA URIs are not a replacement for CDNs but can complement them:

| Feature | DATA URI | CDN | |---------|----------|-----| | Reduces HTTP requests | Yes | No | | Geographic distribution | No | Yes | | Effective for large files | No | Yes | | Requires external service | No | Yes | | Browser caching benefits | Limited | Full |

Conclusion

DATA URIs offer a viable technique for reducing HTTP requests and improving initial page load times, especially for smaller images. While they won't replace CDNs in all scenarios, they provide another tool in your web performance optimization toolkit.

For modern web applications with many small icons and decorative elements, a hybrid approach of CSS sprites, DATA URIs, and CDN-delivered resources often provides the best overall performance.

Note: This article was migrated from the original A thousand nodes blog (2011)

Continue Reading

Browse All Articles