JS怎么实现自动轮播图切换,代码是什么
Admin 2022-08-10 群英技术资讯 499 次浏览
本文实例为大家分享了js实现轮播图自动切换的具体代码,供大家参考,具体内容如下
先看效果图
第一种
//点击按钮,序号变化 showIdx++; if (showIdx == imgArr.length) { showIdx = 0; } //所有盒子左移动 for (let i = 0; i <items.length; i++) { items[i].style.left = parseFloat(items[i].style.left) - loopbox.offsetWidth + "px"; } //冗余容器从页面中删除 //当冗余容器从页面中移除后,为了保证结构想对应,所以呀item中数组也要把这个容器删除 let deleteBox = items.shift(); // console.log(items); deleteBox.remove(); //在用户看不到的内存中,变更【被从这个页面删除的元素的位置 deleteBox.style.left = "900px"; wrapper.appendChild(deleteBox); items.push(deleteBox); //把容器从小添加至压面后,容器加载的图片在当前的下一站 // 第七步 把容器重新添加至页面后,容器加载的图片要是当前这张的下一张 if (showIdx == imgArr.length - 1) { deleteBox.innerHTML = `<img src=${imgArr[0]}>`; } else { deleteBox.innerHTML = `<img src=${imgArr[showIdx + 1]}>`; }
第二种,图片切换,css代码
html, body, ul, li { margin: 0; padding: 0; } a { text-decoration: none; } .loopbox { width: 1226px; height: 460px; background: #030; position: relative; overflow: hidden; } .box { width: 100%; height: 100%; float: left; transition: all .3s; position: absolute; left: 0; /* overflow: hidden; */ } .box.notran{ transition: none; } .box-item { /* width: 100%; */ width: 1226px; height: 100%; float: left; background: #f1f1f1; text-align: center; font-size: 24px; line-height: 100px; /* display: none; */ /* transition: all .3s; */ } .box-item img { width: 100%; height: 100%; /* 图片适应 */ object-fit: cover; } .arrow { width: 60px; line-height: 30px; background: #f00; text-align: center; color: #f1f1f1; position: absolute; top: 50%; left: 10px; margin-top: -15px; border-radius: 15px; } .arrow:hover { background: #f60; } .arrow.arrow-right { left: auto; right: 10px; } .page { position: absolute; width: 100%; text-align: center; bottom: 10px; } .page li { display: inline-block; width: 80px; height: 8px; border-radius: 4px; background: #000; } /* .page li:first-child { background: #f90; } */ .page li:hover { background: #f60; } .page li.current { background: #f90; } .side-qq { width: 100px; height: 100px; background: #f00; /* position: fixed; */ position: absolute; right: 10px; top: 450px; } .navbar { width: 100%; background: #ccc; text-align: center; } .navbar.fixed { position: fixed; left: 0; top: 0; } .nav { height: 21px; }
js
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <link rel="stylesheet" href="./css/index.css"> </head> <body> <!-- 1.分析页面结构 --> <div class="loopbox"> <div id="box" class="box"> <div class="box-item curr"><img src="images/1.webp"></div> <div class="box-item"><img src="images/2.webp"></div> <div class="box-item"><img src="images/3.webp"></div> <div class="box-item"><img src="images/4.webp"></div> </div> <a class="arrow arrow-left" href="javascript:;">左</a> <a class="arrow arrow-right" href="javascript:;">右</a> <ul id="page" class="page"> <li class="current"></li> <li></li> <li></li> <li></li> </ul> </div> <script> // 1.5.初始化页面,保证所有的图片先拍成一排 let items = document.querySelectorAll(".box-item"); let lis = document.querySelectorAll(".page li"); let leftBtn=document.querySelector(".arrow-left") let box = document.querySelector(".box"); let loopbox = document.querySelector(".loopbox"); box.style.width = items.length * loopbox.offsetWidth + "px"; box.style.left = 0+"px"; // 2.分析功能入口 let rightBtn = document.querySelector(".arrow-right"); let showIdx = 0; rightBtn.onclick = function (){ items[showIdx].classList.remove("curr"); lis[showIdx].classList.remove("current"); showIdx ++; if(showIdx == 4){ showIdx = 0; } items[showIdx].classList.add("curr"); lis[showIdx].classList.add("current"); box.style.left = (-1) * showIdx * loopbox.offsetWidth + "px"; for(let i=0;i<lis.length;i++){ lis[i].onclick =function(){ items[showIdx].classList.remove("curr"); lis[showIdx].classList.remove("current"); showIdx=i; items[showIdx].classList.add("curr"); lis[showIdx].classList.add("current"); } } leftBtn.onclick = function(){ //第一张 消失(取消类名) items[showIdx].classList.remove("curr"); lis[showIdx].classList.remove("current"); showIdx --; //预知判断 if(showIdx == -1){ //点击之后,点击之前意味着已经在加,需要归零 showIdx = 3; } items[showIdx].classList.add("curr"); lis[showIdx].classList.add("current"); box.style.left = (-1) * showIdx * loopbox.offsetWidth + "px"; // 第二张 出现(添加类名)showIdx+1 }; for(let j=0;j<lis.length;j++){ lis[j].onclick = function(){ items[showIdx].classList.remove("curr"); lis[showIdx].classList.remove("current"); //选好变为点击序号对应结构 showIdx=j; items[showIdx].classList.add("curr"); lis[showIdx].classList.add("current"); } } } function time(){ items[showIdx].classList.remove("curr"); lis[showIdx].classList.remove("current"); showIdx ++; if(showIdx == 4){ showIdx = 0; } items[showIdx].classList.add("curr"); lis[showIdx].classList.add("current"); box.style.left = (-1) * showIdx * loopbox.offsetWidth + "px"; } for(let i=0;i<lis.length;i++){ lis[i].onclick =function(){ items[showIdx].classList.remove("curr"); lis[showIdx].classList.remove("current"); showIdx=i; items[showIdx].classList.add("curr"); lis[showIdx].classList.add("current"); } } setInterval(time,3000) </script> </body> </html>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在JavaScript中,可以利用for循环语句来实现从1加到50的功能,for循环能够在规定条件下循环执行指定的代码块,语法为“for(var i=1;i<=50;i++){sum+=i;}”。
vue项目在本地构建后,每次热更新都会卡在 75 advanced module optimization 的地方不动了。很影响开发效率有木有,网上一搜给的方案(babel-plugin-dynamic-import-node)试了下各种报错,要么说版本问题,要么说引入文件的方式不对,要么说webpack的配置不对,然
这篇文章主要介绍了解决vant title-active-color与title-inactive-color不生效问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
Nodejs和浏览器中this关键字有何不同?很多朋友对于在this关键字在Nodejs和浏览器环境下的指向问题不是很清楚,接下来通过实例代码给大家详细接下一下。
这篇文章主要给大家介绍了关于react如何实现一个密码强度检测器的相关资料,使用这个密码强度器后可以帮助大家提高在线帐号、个人信息的安全性,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008