search
HomeWeb Front-endJS TutorialDetailed explanation of jQuery lazyload lazy loading

Lazy Load is a jQuery plug-in written in JavaScript. It can delay loading of images in long pages. Images outside the browser's visible area will not be loaded until the user scrolls the page to where they are. This is exactly the opposite of how image preloading is handled.

Lazy loading of images on long pages that contain many large images can speed up page loading. The browser will enter the ready state after loading the visible images. In some cases, it can also help reduce the load on the server.

Demo page:

Basic options

Fade-in effect

For browsers that do not support JavaScript Downgrade processing

Horizontal scrolling

Horizontal scrolling within the container

Vertical scrolling within the container

There are many N pictures in the page

After five years Load images after a delay of seconds

Use AJAX to load images

How to use

Lazy Load relies on jQuery. Please add the following code to the end of the HTML, that is < ;/body>Before:

<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="jquery.lazyload.js"></script>


You have to change the tag of the image. The address of the image must be placed on the data-original attribute. Give lazy loading images a specific class (for example: lazy). This way you can easily do image plugin bundling. The code is as follows:

<img class="lazy" alt="" width="640"    style="max-width:90%" data-original="img/example.jpg" />
$(function() {
 $("img.lazy").lazyload();
});


This will cause all images with class lazy to be loaded lazily.

Demo: Basic Options

TIPS: The width and height of the image must be set here, otherwise the plug-in may not work properly.

Set the threshold

By default, the image will be loaded when it appears on the screen. If you want to load the image in advance, you can set the threshold option. Set the threshold to 200 so that the image is 200 pixels away from the screen. Early loading.

$("img.lazy").lazyload({
 threshold : 200
});


Set events to trigger loading

You can use jQuery events such as click and mouseover. You can also use custom events, such as sporty and foobar. The default is to wait until the user scrolls down and the image appears in the viewport. Load images only when the user clicks on them:

$("img.lazy").lazyload({
 event : "click"
});


Demo: Load images after a five-second delay

Use special effects

By default, the plugin waits for the image to fully load and calls show(). You can use any effect you want. The code below uses fadeIn (fade in effect).

Demo: Fade in effect

$("img.lazy").lazyload({
 effect : "fadeIn"
});


For situations where JavaScript is not enabled

JavaScript for almost all browsers are all enabled. However, you may still want to display real images on clients that do not support JavaScript. To degrade gracefully when the browser does not support JavaScript, you can write the real image fragment in the

<img  class="lazy" data-original="img/example.jpg"    style="max-width:90%" heigh="480" alt="Detailed explanation of jQuery lazyload lazy loading" >
<noscript><img  src="img/example.jpg"    style="max-width:90%" heigh="480" alt="Detailed explanation of jQuery lazyload lazy loading" ></noscript>


##You can hide placeholders through CSS.

.lazy {
 display: none;
}


In browsers that support JavaScript, you must display the placeholder when the DOM is ready, which can be done at the same time as the plugin is initialized.

$("img.lazy").show().lazyload ();

Images in containers

You can use plug-ins on images in scrollable containers, such as DIV elements with scroll bars. All you have to do is define the container as jQuery The object is passed as a parameter to the initialization method.

Demo: horizontal scrolling in the container, vertical scrolling in the container

When the image is not continuous

When scrolling the page, Lazy Load will loop through the loaded images. During the loop, it is checked whether the image is within the visible area. By default, the loop stops when the first image that is not in the visible area is found. The image is considered to be distributed in a streaming manner, and the image is in the page The order is the same as that in HTML code. But in some layouts, this assumption is not true. However, you can control the loading behavior through the failurelimit option.

$("img.lazy").lazyload({
 failure_limit : 10
});


Set failurelimit to 10, so that the plug-in will stop searching only when it finds 10 images that are not in the visible area. If you have a cumbersome layout, please set this parameter higher.

Loading Hide There may be many hidden pictures buried on your page. For example, if the plug-in is used to filter the list, you can constantly modify the display status of each item in the list. In order to improve performance, Lazy Load defaults Hidden images are ignored. If you want to load hidden images, please set skip_invisible to false

$("img.lazy").lazyload({
 skip_invisible : false
});

Download plugin

Latest version source code and compressed code. The plug-in is already available on OSX’s Safari 5.1, Safari 6, Chrome 20, Firefox 12 browsers, Windows’ Chrome 20, IE 8 and IE 9 browsers, and iOS5 (iPhone and Tested on Safari 5.1 browser of iPad).


For more detailed explanations of jQuery lazyload, please pay attention to the PHP Chinese website for articles related to lazy loading!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Replace String Characters in JavaScriptReplace String Characters in JavaScriptMar 11, 2025 am 12:07 AM

Detailed explanation of JavaScript string replacement method and FAQ This article will explore two ways to replace string characters in JavaScript: internal JavaScript code and internal HTML for web pages. Replace string inside JavaScript code The most direct way is to use the replace() method: str = str.replace("find","replace"); This method replaces only the first match. To replace all matches, use a regular expression and add the global flag g: str = str.replace(/fi

8 Stunning jQuery Page Layout Plugins8 Stunning jQuery Page Layout PluginsMar 06, 2025 am 12:48 AM

Leverage jQuery for Effortless Web Page Layouts: 8 Essential Plugins jQuery simplifies web page layout significantly. This article highlights eight powerful jQuery plugins that streamline the process, particularly useful for manual website creation

Build Your Own AJAX Web ApplicationsBuild Your Own AJAX Web ApplicationsMar 09, 2025 am 12:11 AM

So here you are, ready to learn all about this thing called AJAX. But, what exactly is it? The term AJAX refers to a loose grouping of technologies that are used to create dynamic, interactive web content. The term AJAX, originally coined by Jesse J

10 jQuery Fun and Games Plugins10 jQuery Fun and Games PluginsMar 08, 2025 am 12:42 AM

10 fun jQuery game plugins to make your website more attractive and enhance user stickiness! While Flash is still the best software for developing casual web games, jQuery can also create surprising effects, and while not comparable to pure action Flash games, in some cases you can also have unexpected fun in your browser. jQuery tic toe game The "Hello world" of game programming now has a jQuery version. Source code jQuery Crazy Word Composition Game This is a fill-in-the-blank game, and it can produce some weird results due to not knowing the context of the word. Source code jQuery mine sweeping game

How do I create and publish my own JavaScript libraries?How do I create and publish my own JavaScript libraries?Mar 18, 2025 pm 03:12 PM

Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

Load Box Content Dynamically using AJAXLoad Box Content Dynamically using AJAXMar 06, 2025 am 01:07 AM

This tutorial demonstrates creating dynamic page boxes loaded via AJAX, enabling instant refresh without full page reloads. It leverages jQuery and JavaScript. Think of it as a custom Facebook-style content box loader. Key Concepts: AJAX and jQuery

jQuery Parallax Tutorial - Animated Header BackgroundjQuery Parallax Tutorial - Animated Header BackgroundMar 08, 2025 am 12:39 AM

This tutorial demonstrates how to create a captivating parallax background effect using jQuery. We'll build a header banner with layered images that create a stunning visual depth. The updated plugin works with jQuery 1.6.4 and later. Download the

How to Write a Cookie-less Session Library for JavaScriptHow to Write a Cookie-less Session Library for JavaScriptMar 06, 2025 am 01:18 AM

This JavaScript library leverages the window.name property to manage session data without relying on cookies. It offers a robust solution for storing and retrieving session variables across browsers. The library provides three core methods: Session

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.