Home Web Front-end JS Tutorial How to use JavaScript to achieve image switching effect?

How to use JavaScript to achieve image switching effect?

Oct 20, 2023 pm 01:12 PM
javascript image switching

如何使用 JavaScript 实现图片切换效果?

How to use JavaScript to achieve image switching effect?

In web design, we often encounter scenarios where images need to be switched, such as in carousels, slideshows or album displays. Such image switching effects can be easily achieved using JavaScript. This article will introduce a simple method to achieve image switching effect through JavaScript, and provide specific code examples for reference.

First, we need to prepare some HTML structures to accommodate images and trigger switching operations. In a div container, use the img tag to nest the image to be switched, and add a button to trigger the image switching operation. The sample code is as follows:

<div id="imageContainer">
    <img id="image" src="image1.jpg" alt="Image 1">
    <button id="previousButton">上一张</button>
    <button id="nextButton">下一张</button>
</div>
Copy after login

Next, we need to use JavaScript to handle the logic of image switching. First, we need to get the corresponding element and set the corresponding initial value. The sample code is as follows:

// 获取图片容器和按钮元素
const imageContainer = document.getElementById("imageContainer");
const image = document.getElementById("image");
const previousButton = document.getElementById("previousButton");
const nextButton = document.getElementById("nextButton");

// 定义图片切换需要的变量
let currentImage = 1;  // 当前显示的图片序号
const totalImages = 3;  // 总图片数量

// 设置初始显示的图片
image.src = `image${currentImage}.jpg`;

// 为按钮绑定点击事件监听器
previousButton.addEventListener("click", showPreviousImage);
nextButton.addEventListener("click", showNextImage);
Copy after login

Now, we need to implement two functions to handle the switching logic of the previous and next pictures. The sample code is as follows:

// 显示上一张图片的函数
function showPreviousImage() {
    currentImage--;
    if (currentImage < 1) {
        currentImage = totalImages;
    }
    image.src = `image${currentImage}.jpg`;
}

// 显示下一张图片的函数
function showNextImage() {
    currentImage++;
    if (currentImage > totalImages) {
        currentImage = 1;
    }
    image.src = `image${currentImage}.jpg`;
}
Copy after login

In the code, we use a currentImage variable to track the serial number of the currently displayed image. When the "Previous" button is clicked, we decrement currentImage by 1 and check whether it is less than 1. If so, set it to totalImages to achieve the effect of loop switching. When the "Next" button is clicked, we add 1 to currentImage and check whether it is greater than totalImages. If so, set it to 1, which also achieves the effect of loop switching. . Finally, we set the src attribute of the image to the corresponding image path and update the image display.

Finally, we need to perform some initialization operations when the page is loaded to ensure that the correct image is initially displayed. The sample code is as follows:

// 在页面加载完成时执行初始化操作
window.addEventListener("load", function() {
    image.src = `image${currentImage}.jpg`;
});
Copy after login

With the above code, we can achieve a simple image switching effect. The complete code is as follows:

<div id="imageContainer">
    <img id="image" src="image1.jpg" alt="Image 1">
    <button id="previousButton">上一张</button>
    <button id="nextButton">下一张</button>
</div>

<script>
    const imageContainer = document.getElementById("imageContainer");
    const image = document.getElementById("image");
    const previousButton = document.getElementById("previousButton");
    const nextButton = document.getElementById("nextButton");

    let currentImage = 1;
    const totalImages = 3;

    image.src = `image${currentImage}.jpg`;

    previousButton.addEventListener("click", showPreviousImage);
    nextButton.addEventListener("click", showNextImage);

    function showPreviousImage() {
        currentImage--;
        if (currentImage < 1) {
            currentImage = totalImages;
        }
        image.src = `image${currentImage}.jpg`;
    }

    function showNextImage() {
        currentImage++;
        if (currentImage > totalImages) {
            currentImage = 1;
        }
        image.src = `image${currentImage}.jpg`;
    }

    window.addEventListener("load", function() {
        image.src = `image${currentImage}.jpg`;
    });
</script>
Copy after login

The above is the method and code example of using JavaScript to achieve the image switching effect. By defining variables, binding event listeners and updating the src attribute of the image, we can achieve a simple image switching effect in the web page. The code can be appropriately modified and expanded according to specific needs to achieve richer and more complex image switching effects.

The above is the detailed content of How to use JavaScript to achieve image switching effect?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
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

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

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What should I do if I encounter garbled code printing for front-end thermal paper receipts? What should I do if I encounter garbled code printing for front-end thermal paper receipts? Apr 04, 2025 pm 02:42 PM

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

Who gets paid more Python or JavaScript? Who gets paid more Python or JavaScript? Apr 04, 2025 am 12:09 AM

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

Demystifying JavaScript: What It Does and Why It Matters Demystifying JavaScript: What It Does and Why It Matters Apr 09, 2025 am 12:07 AM

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

How to merge array elements with the same ID into one object using JavaScript? How to merge array elements with the same ID into one object using JavaScript? Apr 04, 2025 pm 05:09 PM

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

How to achieve parallax scrolling and element animation effects, like Shiseido's official website?
or:
How can we achieve the animation effect accompanied by page scrolling like Shiseido's official website? How to achieve parallax scrolling and element animation effects, like Shiseido's official website? or: How can we achieve the animation effect accompanied by page scrolling like Shiseido's official website? Apr 04, 2025 pm 05:36 PM

Discussion on the realization of parallax scrolling and element animation effects in this article will explore how to achieve similar to Shiseido official website (https://www.shiseido.co.jp/sb/wonderland/)...

Is JavaScript hard to learn? Is JavaScript hard to learn? Apr 03, 2025 am 12:20 AM

Learning JavaScript is not difficult, but it is challenging. 1) Understand basic concepts such as variables, data types, functions, etc. 2) Master asynchronous programming and implement it through event loops. 3) Use DOM operations and Promise to handle asynchronous requests. 4) Avoid common mistakes and use debugging techniques. 5) Optimize performance and follow best practices.

How to implement panel drag and drop adjustment function similar to VSCode in front-end development? How to implement panel drag and drop adjustment function similar to VSCode in front-end development? Apr 04, 2025 pm 02:06 PM

Explore the implementation of panel drag and drop adjustment function similar to VSCode in the front-end. In front-end development, how to implement VSCode similar to VSCode...

The difference in console.log output result: Why are the two calls different? The difference in console.log output result: Why are the two calls different? Apr 04, 2025 pm 05:12 PM

In-depth discussion of the root causes of the difference in console.log output. This article will analyze the differences in the output results of console.log function in a piece of code and explain the reasons behind it. �...

See all articles