data:image/s3,"s3://crabby-images/0856d/0856d2888a6e3d21abf64526c330a02cfdeb1565" alt=""
data:image/s3,"s3://crabby-images/7b1d8/7b1d88bd685bf8b989c93584fa98d53eda4dc545" alt="Top list of solutions to optimize images for websites"
Top list of solutions to optimize images for websites
Introduction
Image optimization is one of many important solutions to improve website performances, which is quite important and every Front-End developers should know. In this article, I will provide some solutions for you to consider applying for the projects you are working on.
Solutions
Solution 1 β lazy load image
The technique of lazy-loading images is most often mentioned in images optimization. This is a technique to force images to be loaded only after the content on the web page has been scrolled and viewed by the user. This technique is very suitable for e-commerce, photo social networks, travel websites. These include popular sites that are applying such as Shopee, AirBnb, Pinterest, Behance, β¦
In the past developers were required to develop for image lazy loading. However, many browsers now support lazy loading for images, which make developers easy to apply it:
<img data-fr-src="/cat.jpg" loading="lazy" />
However, for sure you should write code to check if the browser supports lazy-loading the image.
if ('loading' in HTMLImageElement.prototype) alert("yes"); else alert("no");
Solution 2 β Use Art direction
Art direction is one of the most common responsive image solutions on large websites like Facebook, Instagram, β¦ This is a technique to automatically load images according to the device's size. For example, when visiting website in mobile device, the smaller image will be loaded in the correct size for mobile, instead of loading a large image from Desktop device. However, this is required your system supports doing scale images by multiple sizes requested.
You can use HTML code:
<picture> <source media="(max-width: 799px)" srcset="elva-480w-close-portrait.jpg" /> <source media="(min-width: 800px)" srcset="elva-800w.jpg" /> <img src="elva-800w.jpg" alt="Chris standing up holding his daughter Elva" /> </picture>
Or CSS:
@media (min-width: 769px) { .bg { background-image: url(bg1080.jpg); } } @media (max-width: 768px) { .bg { background-image: url(bg768.jpg); } }
Solution 3 β Use Webp file type
WebP is an image file format developed by Google silently intended as a replacement for JPEG, PNG, and GIF file formats. It supports both lossy and lossless compression, as well as animation and alpha transparency. At the present time, more than 90% of the world's browsers support the WebP format. Including FireFox, Chrome, Opera and even Safari from Apple.
WebP format reduces image file size from about 19% to 64%. This makes websites load faster and consume less bandwidth. It can be said that if an image have same the quality, other formats will consume more space in disk than webp format.
To convert your image into using webp format, you can visit: https://cloudconvert.com/webp-converter
Conclusion
Image Optimization is not easy and requires an understanding of both frontend and backend development. If you are working on an application that has a lot of traffic and consumes a lot of images loaded per visit, you definitely need to know the above techniques. If you know any other good image optimization techniques, please share in the comments!
Related Blogs
data:image/s3,"s3://crabby-images/0856d/0856d2888a6e3d21abf64526c330a02cfdeb1565" alt=""
data:image/s3,"s3://crabby-images/5ec40/5ec40b65249cb7588858fad175fb82524915fef1" alt=""
data:image/s3,"s3://crabby-images/5d9d3/5d9d38a499f97214b567ae87f2e3b5c5c5bf3e75" alt=""
data:image/s3,"s3://crabby-images/f27dc/f27dc6a1e670ec35d511e3ad6347ccee57061507" alt=""
data:image/s3,"s3://crabby-images/65312/653121ecacf60f7a3985111cc6455e9a0e2aca56" alt=""
data:image/s3,"s3://crabby-images/88873/888733ba145445c5ce3b6d00ec6e0fe0155f8cde" alt=""
data:image/s3,"s3://crabby-images/c0c16/c0c16f401ad66d71e0191c4720734497aefe6b06" alt=""
data:image/s3,"s3://crabby-images/d280d/d280db064f284647032f51394dcb5a376be52e9a" alt=""
data:image/s3,"s3://crabby-images/706b0/706b0cf737814ae6f94c518e7e4ae0f083d9c02e" alt=""
data:image/s3,"s3://crabby-images/defd9/defd99772b914501db4f7771363fdfde07a507b2" alt=""
data:image/s3,"s3://crabby-images/917e1/917e1755c102dc28cb3e763cd9d8dce74ed9b554" alt=""
data:image/s3,"s3://crabby-images/f76a0/f76a0add21c8d12d98b198ab674cb0001d344392" alt=""
data:image/s3,"s3://crabby-images/4f136/4f13638c58b2550d14476d53103521638ab40d09" alt=""
data:image/s3,"s3://crabby-images/dea89/dea89e5ca091c3abbba60b6cd6fe7b461f054e34" alt=""
data:image/s3,"s3://crabby-images/6215d/6215d836d45359f0f4f60c787d63873243115929" alt=""
data:image/s3,"s3://crabby-images/52d05/52d057e8d8c4176e832d565ff57f48727638c216" alt=""
data:image/s3,"s3://crabby-images/fa4c3/fa4c3bc5b59c1417b4b2cff4afabbd91cd5c0349" alt=""