这篇文章将为大家详细讲解有关怎么实现js焦点轮播效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
创新互联-专业网站定制、快速模板网站建设、高性价比瑞昌网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式瑞昌网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖瑞昌地区。费用合理售后完善,10年实体公司更值得信赖。效果如图:
实现代码:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> *{ margin: 0; padding: 0; list-style: none; text-decoration: none; } .wrap{ width: 490px; height: 170px; margin: 100px auto; border: 1px solid #000000; position: relative; overflow: hidden; } #pic{ width: 3430px; position: absolute; } #pic li{ float: left; height: 170px; } #list{ position: absolute; bottom: 10px; left:150px ; } #list li{ float: left; width: 15px; height: 15px; background: #fff; margin: 0 10px; border-radius: 50%; cursor: pointer; } #list .on{ background: #e27a00; } .Prev{ top: 30px; left: 0; } .Next{ top: 30px; right: 0; } .Prev,.Next{ position: absolute; font-size: 80px; font-weight: bold; color:#fff ; -webkit-transition: all 0.35s ease-in-out } .Next:hover, .Prev:hover{ background: #ccc; background: rgba(204, 204, 204, 0.4); } </style> <script type="text/javascript"> window.onload=function(){ var wrap=document.getElementById('wrap'); var pic=document.getElementById('pic'); var Li=document.getElementById('list').getElementsByTagName('li'); var prev=document.getElementById('Prev'); var next=document.getElementById('Next'); var animated=false; var index=0; var timer=null; next.onclick=function(){ if(animated){//如果图片正在滚动时要返回,否则index会变化 return; } else{ index++; if(index>=Li.length){ index=0; } } showlist(); if(animated == false){//if(!animated) animate(-490); } } prev.onclick=function(){ if(animated){ return; } else{ index--; if(index<=0){ index=Li.length-1; } } showlist(); if(!animated){//判断其是否滚动完 animate(490); } } for(var i=0;i<Li.length;i++){ Li[i].num=i; Li[i].onclick=function(){ if(this.className=="on"){ return; } var offset = -490*(this.num-index); if(!animated){ animate(offset); } index=this.num; showlist(); } } //图片变换 function animate(offset){ animated=true; var newLeft=parseInt(pic.style.left) + offset; var time=300//位移总时间 var interval=10;//位移间隔时间 var speed=offset/(time/interval);//每次位移量 function go(){ if((speed < 0 && parseInt(pic.style.left) > newLeft )|| (speed > 0 && parseInt(pic.style.left) < newLeft)){ pic.style.left = parseInt(pic.style.left) + speed + 'px'; setTimeout(go,interval); }else{ animated=false; pic.style.left= newLeft + 'px'; if(newLeft > -490){ pic.style.left = -2450 + 'px'; } if(newLeft < -2450){ pic.style.left = -490 + 'px'; } } } go(); } //圆点变换 function showlist(){ for(var i=0;i<Li.length;i++){ Li[i].className=""; } Li[index].className="on"; } //自动播放 function play(){ timer=setInterval(function(){ next.onclick(); },2000); } function stop(){ clearInterval(timer); } wrap.onmouseover=stop; wrap.onmouseout=play; play(); } </script> </head> <body> <div class="wrap" id="wrap"> <ul id="pic" > <li><a href="#"><img src="/54111d7d00018ba604900170.jpg" alt="5"/></a></li> <li><a href="#"><img src="/54111cd9000174cd04900170.jpg" alt="1"/></a></li> <li><a href="#"><img src="/54111dac000118af04900170.jpg" alt="2"/></a></li> <li><a href="#"><img src="/54111d9c0001998204900170.jpg" alt="3"/></a></li> <li><a href="#"><img src="/54111d8a0001f41704900170.jpg" alt="4"/></a></li> <li><a href="#"><img src="/54111d7d00018ba604900170.jpg" alt="5"/></a></li> <li><a href="#"><img src="/54111cd9000174cd04900170.jpg" alt="1"/></a></li> </ul> <ul id="list"> <li class="on"></li> <li></li> <li></li> <li></li> <li></li> </ul> <a href="javascript:;" class="Prev" id="Prev"><</a> <a href="javascript:;" class="Next" id="Next">></a> </div> </body> </html>
关于“怎么实现js焦点轮播效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网站名称:怎么实现js焦点轮播效果-创新互联
网站链接:https://www.cdcxhl.com/article0/pspio.html
成都网站建设公司_创新互联,为您提供ChatGPT、网站内链、面包屑导航、虚拟主机、品牌网站制作、建站公司
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联