Efficiently implement lazy loading of web page images: taking into account both responsiveness and performance
Have you ever considered lazy loading of images to optimize web page performance? Lazy loading technology can effectively reduce the load weight of the initial page and improve the loading speed of the web page. This article will explore an efficient image lazy loading method, while taking into account responsive images and the best user experience.
Lazy loading is not a browser native function, and it currently needs to be implemented with the help of JavaScript. Although Chrome 75 and subsequent versions plan to natively support lazy loading of images and iframes, we still need to use JavaScript solutions in order to be compatible with other browsers. Many static website generators, libraries, and frameworks provide lazy loading capabilities out of the box, but introducing a full library or framework just to implement this functionality can cause performance overhead. Therefore, we chose to implement lazy loading by ourselves.
Core mechanism:
Most lazy loading methods follow the following pattern:
HTML tags: Use
<img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/174502705448368.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Tips for rolling your own lazy loading">
Loading time: Use
Intersection Observer
API to detect whether the image enters the viewport.Intersection Observer
provides efficient element visibility detection, avoiding frequentscroll
andresize
event listening.
// Create Intersection Observer const observer = new IntersectionObserver(lazyLoad, { rootMargin: '100px', threshold: 1.0 }); function lazyLoad(elements) { elements.forEach(image => { if (image.intersectionRatio > 0) { image.src = image.dataset.src; observer.unobserve(image); } }); } // Observe all img elements with "lazy" class const lazyImages = document.querySelectorAll('img.lazy'); lazyImages.forEach(img => { observer.observe(img); });
Improvement and optimization:
There are some shortcomings in the above basic methods:
- JavaScript dependency: The image cannot be displayed until JavaScript is loaded and executed.
- Visual beating: The page is blank before the picture is loaded, which may cause visual dissatisfaction.
In response to the above issues, we have made the following improvements:
- Native lazy load detection: Use feature detection to determine whether the browser supports the native
loading="lazy"
attribute. If supported, use it directly without JavaScript intervention.
if ('loading' in HTMLImageElement.prototype) { document.querySelectorAll('img.lazy').forEach(img => img.src = img.dataset.src); } else { // Use Intersection Observer to implement lazy loading}
- Placeholder map and CSS transition: Use a small-size placeholder map as the initial state, and use CSS to scale and blur, remove the blur effect after the image is loaded to achieve a smooth transition.
<picture> <img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/174502705554652.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Tips for rolling your own lazy loading"> </picture>
picture { width: 100%; overflow: hidden; } picture img { width: 100%; transition: filter 0.5s; } picture.lazy img { filter: blur(20px); }
- Responsive picture: Use
<picture></picture>
Elements and<source></source>
Elements implement responsive pictures, loading pictures of different sizes according to different viewport sizes.
Auxiliary tools:
To simplify the development process, we can use the following auxiliary tools:
HTML generator: custom function or template engine assisted in generation
<picture></picture>
HTML code for the element.Image batch processing: Use tools such as
gulp-image-resize
to batch generate pictures of different sizes, or use cloud services (such as Netlify and Cloudinary) to convert pictures on demand.
Summarize:
This article introduces an efficient image lazy loading implementation method. By combining native lazy loading feature detection, placeholder map, CSS transition, responsive pictures and auxiliary tools, it can improve the user experience while ensuring performance. Choosing the right image processing method (build or on-demand conversion) depends on the project size and requirements. This method can significantly improve web page loading speed and provide smoother visual effects.
The above is the detailed content of Tips for rolling your own lazy loading. For more information, please follow other related articles on the PHP Chinese website!

Choosing Flexbox or Grid depends on the layout requirements: 1) Flexbox is suitable for one-dimensional layouts, such as navigation bar; 2) Grid is suitable for two-dimensional layouts, such as magazine layouts. The two can be used in the project to improve the layout effect.

The best way to include CSS files is to use tags to introduce external CSS files in the HTML part. 1. Use tags to introduce external CSS files, such as. 2. For small adjustments, inline CSS can be used, but should be used with caution. 3. Large projects can use CSS preprocessors such as Sass or Less to import other CSS files through @import. 4. For performance, CSS files should be merged and CDN should be used, and compressed using tools such as CSSNano.

Yes,youshouldlearnbothFlexboxandGrid.1)Flexboxisidealforone-dimensional,flexiblelayoutslikenavigationmenus.2)Gridexcelsintwo-dimensional,complexdesignssuchasmagazinelayouts.3)Combiningbothenhanceslayoutflexibilityandresponsiveness,allowingforstructur

What does it look like to refactor your own code? John Rhea picks apart an old CSS animation he wrote and walks through the thought process of optimizing it.

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@keyframesispopularduetoitsversatilityandpowerincreatingsmoothCSSanimations.Keytricksinclude:1)Definingsmoothtransitionsbetweenstates,2)Animatingmultiplepropertiessimultaneously,3)Usingvendorprefixesforbrowsercompatibility,4)CombiningwithJavaScriptfo

CSSCountersareusedtomanageautomaticnumberinginwebdesigns.1)Theycanbeusedfortablesofcontents,listitems,andcustomnumbering.2)Advancedusesincludenestednumberingsystems.3)Challengesincludebrowsercompatibilityandperformanceissues.4)Creativeusesinvolvecust

Using scroll shadows, especially for mobile devices, is a subtle bit of UX that Chris has covered before. Geoff covered a newer approach that uses the animation-timeline property. Here’s yet another way.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Notepad++7.3.1
Easy-to-use and free code editor

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
