Playing With Data URIs
March 21, 2013
Following up on my post yesterday, I thought I should quickly play with data URIs to see what they can do for performance. This is strictly sharing my learning and testing, not an explanation of how data URIs work.
I have no idea what I'm doing.
I really don't have a grasp on this tech yet. I've read about them in lots of posts, but haven't really messed with them much. I mean, I understand that they are a way of writing the code for an asset directly into the HTML. How that works, how to troubleshoot or how to explain oddities are currently beyond my skillzzz.
I feel dirty and better at the same time.
Using them is kind of like drinking a natural vegetable shake. You know it's good for you, but it's icky and makes you shudder. The code that makes them is insane. Putting Sublime Text into full screen mode with my 1440x900 resolution, it takes 3-4 full swipes to scroll past the code.
It is really easy, though. You drag your image into an encoder, copy, and paste the code into the src="" of your image. Boom!
The Results (Home Page Only So Far)
I'm not 100% sure about the results. What I can see is that the page weight went down (very surprisingly, but thanks to gzip). The page load time went down, but the requests stayed the same. This was a little bit of a WTF moment for me. I'll spend a little more time trying to dig up an answer because I was expecting it to be reduced by the 10 SVGs that are now data URIs.
linked SVG 229 KB vs. 185 KB data URI
linked SVG 20 vs. 20 data URI
Page Load Time:
linked SVG 1.67 seconds vs. 1.29 seconds data URI