请手写一个幻灯片的效果

在前端开发中,实现一个幻灯片效果通常涉及到HTML、CSS和JavaScript的使用。下面是一个简单的幻灯片效果示例,使用纯JavaScript进行图片切换。

HTML

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>简单幻灯片效果</title>
    <link rel="stylesheet" href="styles.css">
</head>
<body>
    <div class="slideshow">
        <img id="slideshowImage" src="image1.jpg" alt="Slideshow Image">
        <button id="prevButton">上一张</button>
        <button id="nextButton">下一张</button>
    </div>
    <script src="script.js"></script>
</body>
</html>

CSS (styles.css)

body {
    font-family: Arial, sans-serif;
    text-align: center;
}

.slideshow {
    position: relative;
    max-width: 600px;
    margin: 0 auto;
}

#slideshowImage {
    width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
}

button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px;
    cursor: pointer;
}

#prevButton {
    left: 10px;
}

#nextButton {
    right: 10px;
}

JavaScript (script.js)

document.addEventListener('DOMContentLoaded', function() {
    const images = ['image1.jpg', 'image2.jpg', 'image3.jpg']; // 图片数组,根据需要替换
    let currentIndex = 0;
    const slideshowImage = document.getElementById('slideshowImage');
    const prevButton = document.getElementById('prevButton');
    const nextButton = document.getElementById('nextButton');
    
    // 更新图片函数
    function updateImage() {
        slideshowImage.src = images[currentIndex];
    }
    
    // 上一张图片事件处理函数
    prevButton.addEventListener('click', function() {
        currentIndex--;
        if (currentIndex < 0) {
            currentIndex = images.length - 1; // 循环到最后一张图片
        }
        updateImage();
    });
    
    // 下一张图片事件处理函数
    nextButton.addEventListener('click', function() {
        currentIndex++;
        if (currentIndex >= images.length) {
            currentIndex = 0; // 循环到第一张图片
        }
        updateImage();
    });
});

这个示例中,我们创建了一个包含图片、上一张和下一张按钮的幻灯片。通过JavaScript数组来存储图片路径,并使用currentIndex变量来跟踪当前显示的图片。点击按钮时,会更新currentIndex并重新加载图片。如果到达数组的末尾或开头,则会循环到另一端,实现连续播放的效果。

posted @   王铁柱6  阅读(2)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示