<!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>轮播效果</title> <style> *{ margin: 10; padding: 0; } #banner{ width: 640px; height: 300px; margin: 0 auto; position:relative; } ul{ list-style: none; } .imgList li{ position:absolute; left: 0; top:0; } #left_btn,#right_btn{ width: 38px; height: 61px; display: block; position:absolute; z-index: 2; } #left_btn{ background: url(images/themes.gif); top:125px; } #right_btn{ background: url(images/themes.gif) -38px; right: 0; top:125px; } .focusList{ position: absolute; bottom: 20px; right: 150px; z-index: 3; } .focusList a{ width: 30px; height: 30px; float: left; background: rgba(255, 254, 254, 0.5); border-radius: 50%; margin-left: 10px; } .focusList a.cur{ background: red; } </style> <script src="jquery.js"></script> </head> <body> <div id="banner"> <ul class="imgList"> <li style="z-index:1"> <a href=""> <img src="images/1.jpg" alt=""> </a> </li> <li> <a href=""> <img src="images/2.jpg" alt=""> </a> </li> <li> <a href=""> <img src="images/3.jpg" alt=""> </a> </li> <li> <a href=""> <img src="images/4.jpg" alt=""> </a> </li> </ul> <a href="" id="left_btn"></a> <a href="" id="right_btn"></a> <div class="focusList"> <a href="javascript:void(0)" class="cur"></a> <a href="javascript:void(0)"></a> <a href="javascript:void(0)"></a> <a href="javascript:void(0)"></a> </div> </div> <script> console.log($("li")); console.log($(".focusList a")); function changeImg(xiabiao){ $("li").eq(xiabiao).fadeIn().siblings().fadeOut();//siblings()方法返回被选元素的所有同胞元素。 $(".focusList a").eq(xiabiao).addClass("cur").siblings().removeClass("cur"); } var step=0; var timer=null; changeImg(step); function autoPlay(){ timer=setInterval(function() { step++;//每隔一秒要加一 if(step==4){ step=0; } changeImg(step);//调用函数 },1000) } autoPlay(); $("#left_btn").click(function(){ clearInterval(timer); step--; if(step==-1){ step=4; } changeImg(step); autoPlay(); }); $("#right_btn").click(function(){ clearInterval(timer); step++; if(step==5){ step=0; } changeImg(step); autoPlay(); }); $(".focusList a").click(function(){ clearInterval(timer); step=$(this).index();//单击的索引值step传到changeImg(xiabiao) changeImg(step); autoPlay(); }); </script> </body> </html>为什么左右按钮不能实现功能
时间: 2023-08-14 17:44:32 浏览: 165
左右按钮不能实现功能可能是因为以下几个原因:
1. 按钮的 href 属性为空,应该给左右按钮添加点击事件,而不是跳转链接。
2. 点击按钮时没有清除定时器,应该在按钮点击事件中清除定时器,否则定时器会一直执行导致轮播速度加快。
3. 变量 step 的值在点击按钮时没有更新,应该在按钮点击事件中更新 step 的值。
你可以尝试修改代码来解决这些问题,使得左右按钮能够正常实现轮播功能。
阅读全文