使用JS完成首页轮播图效果

原文链接:http://blog.csdn.net/so_zxn/article/details/79133486

如有错误或者需要改进的地方欢迎留言指导,喜欢的话就点赞,或者收藏。谢谢

首先看下结构目录:







接下来是简单的代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>使用JS完成首页轮播图效果test</title>
<style>
/*执行顺序思路:
* 第一步:确定事件(onload)并为其绑定一个函数
                                        第二步:书写绑定的这个函数
                                       第三步:书写定时任务(setInterval)
                                       第四步:书写定时任务里面的函数
                                      第五步:通过变量的方式,进行循环*/
div{
border: 1px solid wheat;
width: 600px;
height: 400px;
margin: auto;
text-align: center;
}
</style>
<script>
function init(){
setInterval("changeImg2()",1000)
}
var i=0;
function changeImg2(){
i++;
document.getElementById("img2").src="../img/"+i+".jpg"
if (i==3) {
i=0;
}
}
</script>
</head>
//注意οnlοad="init()"事件必须写在<body></body>标签内
<body οnlοad="init()">
<div>
<img src="../img/1.jpg" id="img2" width="100%" height="100%" />
</div>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用 JavaScript 实现轮播图的示例代码,包括小圆点、标题和色块: HTML 代码: ```html <div class="slider"> <ul class="slides"> <li class="slide active"> <img src="slide1.jpg" alt="Slide 1" /> <div class="content"> <h2>Title 1</h2> <p>Description 1</p> </div> </li> <li class="slide"> <img src="slide2.jpg" alt="Slide 2" /> <div class="content"> <h2>Title 2</h2> <p>Description 2</p> </div> </li> <li class="slide"> <img src="slide3.jpg" alt="Slide 3" /> <div class="content"> <h2>Title 3</h2> <p>Description 3</p> </div> </li> </ul> <div class="dots"></div> </div> ``` CSS 代码: ```css .slider { position: relative; } .slides { list-style: none; margin: 0; padding: 0; } .slide { position: absolute; top: 0; left: 0; opacity: 0; transition: opacity 0.5s ease-in-out; } .slide.active { opacity: 1; } .content { position: absolute; bottom: 0; left: 0; width: 100%; padding: 10px; background-color: rgba(0, 0, 0, 0.5); color: #fff; } .content h2 { margin: 0; font-size: 24px; } .content p { margin: 0; font-size: 16px; } .dots { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); display: flex; } .dot { width: 10px; height: 10px; margin: 0 5px; border-radius: 50%; background-color: #ccc; cursor: pointer; } .dot.active { background-color: #fff; } ``` JavaScript 代码: ```js const slides = document.querySelectorAll('.slide'); const dots = document.querySelector('.dots'); let currentSlide = 0; let interval = setInterval(nextSlide, 5000); function nextSlide() { slides[currentSlide].classList.remove('active'); currentSlide = (currentSlide + 1) % slides.length; slides[currentSlide].classList.add('active'); updateDots(); } function updateDots() { dots.innerHTML = ''; for (let i = 0; i < slides.length; i++) { const dot = document.createElement('div'); dot.classList.add('dot'); if (i === currentSlide) { dot.classList.add('active'); } dot.addEventListener('click', () => { slides[currentSlide].classList.remove('active'); currentSlide = i; slides[currentSlide].classList.add('active'); updateDots(); clearInterval(interval); interval = setInterval(nextSlide, 5000); }); dots.appendChild(dot); } } updateDots(); ``` 这段代码实现了一个自动轮播的效果,每 5 秒钟自动切换到下一张图片,并且在图片下方添加了小圆点和标题、色块等内容。当用户点击小圆点时,会切换到对应的图片,并且停止自动轮播,等待 5 秒钟后重新开始自动轮播。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值