Why Image Compression is important for Web Design? Images and videos on a website continue to grow, which result in slower load times and a negative user experience.
Here’s a look at most common mistakes you may be making when it comes to managing images:
Not Using More Efficient, Modern Image Formats
Even though Google and Microsoft has their own modern image formats (WebP, JPEG-XR), developers have still not embraced them.
Perhaps you aren’t aware of these formats. Or maybe it’s too difficult to deliver different image formats to various browsers and devices. As a result, you may be sticking with the same JPG and PNG formats. And We are not taking advantage of how the modern formats can optimize their sites.
How to fix: Convert images to the WebP and JPEG-XR modern formats. It also adjusts image compression quality to balance between the formats. Also by detecting the specific browser that accesses each image and delivering a different version of the image to the respective browser, you can ensure users receive the best images possible, in terms of visual quality and file size optimization.
16.9KB JPG 6.9KB WebP
Embedding Short Video Clips Using the GIF Format
You may rely on the GIF image format to display short video clips on news sites, media sites and social sharing sites. While we can use the GIF format easily for embedding video clips using a simple HTML image tag, it is not efficient for captured movies because the files are huge and slow to load, especially on mobile devices, resulting in high bandwidth costs and high CPU utilization.
How to fix: There are several ways to deliver and embed the same clips and animations using modern file formats, such as Animated WebP for Chrome browser users. Another approach is to apply lossy image compression of the GIF file, which results in a slight visual quality reduction but significantly decreases the file size.
We can convert GIF files also to MP4 or WebM video formats, embedding the clips and HTML5 video tags instead of the image tag. In most modern browsers, this works smoothly and the site looks exactly the same but loads much faster. By taking one of these steps, you will be able to reduce the file size dramatically, saving page load time, improving user experience and cutting bandwidth costs.
6.3MB GIF 311KB MP4
Delivering 2X (Retina Display) Images to All Users
Modern mobile devices and laptops have high device pixel ratios (DPR). Because you want your sites to look great on these devices, you may be embedding double resolution images. While this is a good practice, many developers tend to deliver the same size images to all users. As a result, users with regular displays (e.g., non-Retina displays) must download the hi-res images while their displays only benefit from half the resolution. This results in wasted time waiting for pages to load and increases bandwidth costs unnecessarily.
How to fix: Create different resolutions for each DPR value (e.g., regular images and double resolution images) and automatically detect the DPR value of the web page in the current user’s browser. This will enable you to deliver regular images to users with regular displays and 2x resolution images to users with retina display devices.
DPR 1.0 – 100×100 – 4.6KB DPR 2.0 – 200×200 – 12.1KB
Image Compression: Wasteful Browser-Side Resizing
One of the common shortcuts developers employ is using browser-side image resizing instead of resizing images on the server-side. On modern browsers, the end result looks exactly the same, but bandwidth-wise the story is quite different. Website visitors waste precious time downloading an unnecessarily large image and you waste bandwidth delivering it to them. For older browsers, the problem is even more pronounced as their resizing algorithms are usually sub-par.
How to fix: Make sure the images you deliver perfectly fit their required website dimensions. Even if the same image should be made into different sized thumbnails to fit different pages, it’s well worth creating different thumbnails rather than delivering a large image and relying on the browser to resize it.
Example of wasteful browser-side resizing
Unnecessarily High Quality JPEGs
JPEGs have truly revolutionized the web. For many years now, this lossy format has allowed web developers to depict high resolution images with great detail using a fraction of the bandwidth required by any rival image format. But many developers and graphic designers don’t experiment with JPEG image compression, which could significantly reduce file size without a discernible loss in viewing quality.
While 85 percent JPEG quality seems common, we’ve seen many websites in which 95 percent quality was common while a much lower quality would have significantly reduced file size without harming the overall experience. The end result is a higher bandwidth consumption and a dent in the visitors experience.
How to fix: Don’t be afraid to experiment with lower JPEG quality levels. For certain websites, using a 50 percent JPEG quality yielded a very reasonable result and the benefits far outweighed the costs. While higher quality JPEGs will always look better, the improvement in quality will not always be worth the extra bandwidth and waiting times.
95% JPEG – 34KB 80% JPEG – 17KB
Forgetting to Strip Image Metadata
Many modern websites allow visitors to upload photographs. Whether it’s the user’s profile picture or a photo from a recent trip, people often use a modern camera, which bring a lot of meta-data into the photo. In the majority of the cases, it would be an excellent idea to strip this meta-data off. However developers rarely take the time to do so, which results in the images requiring more bandwidth.
How to fix: Make sure to strip the meta-data off your images and user uploaded photos. If this information is necessary, you can keep it available somewhere, just not as part of your images. Even if the image metadata is not necessary for your website, there’s one snippet of information, the image’s original shooting orientation, that’s actually critical for correctly displaying the photo on your website. When stripping the Exif info, make sure you rotate the image to its correct orientation based on its Exif data before losing this information.
Incorrect Image File Types
JPEG, PNG and GIF are the most common file formats used on websites today. Each one has very different roles, so if you use the wrong format you’re wasting your visitors’ time and your own money.
A frequent mistake is using PNGs to deliver photographs. There is a common misconception that PNGs, as lossless formats, will yield the highest possible reproduction for the photos. While this is generally true, this is also quite an unnecessary optimization. A JPEG with relatively high quality will return a photo of a comparable quality at a fraction of the PNG’s file size.
How to fix: Always keep in mind what image format should be used for the content shown. PNG should be used for computer generated images (charts, logos, etc.) or when you need transparency in your images. JPEG should be used when you are showing a captured photograph. GIF should be use when animation is needed (Ajax loading animation, etc.).
PNG – 110KB JPEG – 15KB
Delivering Non-Optimized Images
Even though PNG is a lossless format, you can compress it with freely available image compression tools that reduce it by up to 50 percent yet still deliver the exact same image. Unfortunately, many developers and web designers skip this step and deliver non-optimized images.
How to fix: PNGCrush and OptiPNG are two open-source image compression libraries. If you’re not using these already, you should definitely check them out. If you don’t need to automate the optimization process, you can head to Yahoo’s online smush.it service to manually compress your PNGs even further.
An example of Yahoo smush.it in action
This article, while no means comprehensive, outlines the most common image-related issues that you can fix easily and cost-effectively, eliminating excessive bandwidth usage and providing a better experience for your website visitors. In the final part of this series, we’ll talk about tips for ensuring network optimization when delivering images.