首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js代码写轮播图

当然,下面是一个使用JavaScript编写的简单轮播图示例。这个轮播图将自动切换图片,并且可以通过点击左右箭头手动切换。

HTML部分

代码语言:txt
复制
<!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="carousel">
        <div class="carousel-inner">
            <img src="image1.jpg" alt="Image 1" class="active">
            <img src="image2.jpg" alt="Image 2">
            <img src="image3.jpg" alt="Image 3">
        </div>
        <button class="prev">&#10094;</button>
        <button class="next">&#10095;</button>
    </div>
    <script src="script.js"></script>
</body>
</html>

CSS部分(styles.css)

代码语言:txt
复制
.carousel {
    position: relative;
    width: 80%;
    margin: auto;
}

.carousel-inner {
    position: relative;
    overflow: hidden;
    width: 100%;
}

.carousel-inner img {
    display: none;
    width: 100%;
    height: auto;
}

.carousel-inner img.active {
    display: block;
}

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

.prev {
    left: 10px;
}

.next {
    right: 10px;
}

JavaScript部分(script.js)

代码语言:txt
复制
const images = document.querySelectorAll('.carousel-inner img');
const prevButton = document.querySelector('.prev');
const nextButton = document.querySelector('.next');
let currentIndex = 0;

function showImage(index) {
    images.forEach((img, i) => {
        img.classList.toggle('active', i === index);
    });
}

function nextImage() {
    currentIndex = (currentIndex + 1) % images.length;
    showImage(currentIndex);
}

function prevImage() {
    currentIndex = (currentIndex - 1 + images.length) % images.length;
    showImage(currentIndex);
}

// 自动切换图片
setInterval(nextImage, 3000);

// 点击按钮切换图片
nextButton.addEventListener('click', nextImage);
prevButton.addEventListener('click', prevImage);

解释

  1. HTML部分:定义了轮播图的结构,包括图片容器和前后切换按钮。
  2. CSS部分:设置了轮播图的样式,包括图片的显示和隐藏,以及按钮的位置和样式。
  3. JavaScript部分
    • showImage函数用于显示指定索引的图片,并隐藏其他图片。
    • nextImageprevImage函数用于切换到下一张或上一张图片。
    • setInterval函数用于自动切换图片,每3秒切换一次。
    • 为前后按钮添加点击事件监听器,点击按钮时切换图片。

这个示例展示了如何使用JavaScript实现一个简单的轮播图功能。你可以根据需要进一步扩展和优化这个轮播图,例如添加过渡动画、指示器等。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • JS实现超简易轮播图

    JS代码 1.原理 由于轮播图已经横向排列, 所以只要控制.swiper向x轴偏移距离, 就可以实现图片切换, 这里使用transform的translate属性来控制x轴偏移.可以通过transition...代码使用ES6语法, 这些无所谓, 具体逻辑知道就行 1.构造器 构造器接收一个变量, 切换轮播图的延时....在构造器里新建了一些常量, 轮播图的DOM, 轮播图片的DOM数组, 轮播图的个数(注意是没有初始化前的图片个数), 以及赋值延时(默认是1000ms) 随后调用初始化函数 constructor (delay...随后, 将轮播图显示的位置定在第一张图片位置, 即1的位置 currentPosition变量用于标记当前滚动的图片 init () { // 将轮播图第一项克隆, 并放在最后 const cloneFirst...(2000) slider.start() } 4.整体代码 <!

    10.4K30

    JS实现焦点图轮播效果

    还有一个问题需要注意,此焦点图轮播器其实只有五张图,但是在id为list的div里却放了七张图,这是为啥呢?...)的时候,再进行向右切换的时候,这时最后一张图片被切换进来,此时left值已经为-3600px,并且同时我们又将其left值改为-600px,这样就回到了真正的第一张图。...那么如果没有那两张图片作为过渡的话,效果就会是这样,当轮播到最后一张的时候会闪一下就没有了: ?...好了,最重要的还是JS实现轮播效果: 首先来实现最简单的通过左右按钮来实现切换: window.onload = function () { var container = document.getElementById...OK,整理一下代码: window.onload = function () { var container = document.getElementById('container');

    15.2K61

    JS经典案例-无缝滚动轮播图(纯JS)

    引言 在数字化时代洪流中,无缝滚动轮播图作为网页设计的常青元素,不仅仅是视觉盛宴的开启者,更是用户体验交互的艺术展现。...效果图 需求 制作一款无缝滚动轮播图,具备以下特性: 自动无缝滚动切换图片 ️ 鼠标悬停暂停轮播,离开恢复轮播 向左/向右按钮切换图片 底部小圆点指示当前图片并可点击切换 思路 图片容器无缝衔接...代码 难点: 如何使图片在第一张时点击上一张,向左滚动切换到最后一张。...box.onmouseleave=function(){ timer=setInterval(nextClick,1000) } 总结 总而言之,无缝滚动轮播图作为前端开发中的经典实践...随着技术的演进,未来轮播图的设计将更加注重无障碍性、性能优化与个性化定制,持续为网络空间的每一个角落增添无限生机与想象。

    1K10

    作业-原生js完成轮播图与悬停

    代码亮点:增加图片时,你只需要再加一个li就可以了。不需要改动其他任何代码。 完整代码直接看文章结尾! 首先我们看一下需求 ?...下面我们进入js实现功能的环节。 js 我们先简单构思一下如何让图片自动轮播 假设我们现在有一个定时器,我们传入一个功能,他可以自动切换图片的名称。...下面我们先将图片和列表在js中获取, var lis = document.getElementsByTagName("li"); var img = document.getElementById("...怎么让它悬停在列表12345的时候停止呢,很简单,我们在列表中绑定一个函数,让它停止即可,这里为了代码简洁,我们直接集成到chose函数中即可....=1){ lis[i-2].className = "cout"; } 此时js的完整代码为 <script type

    8K31
    领券