Lv729254729 2022-05-20 10:27 采纳率: 63.6%
浏览 62
已结题

轮播图片为什么每张都链接到同一个网页?

如题。

代码如下。代码是@学习是人类进化的阶梯 的,我在粘贴代码的过程中遇到了这个问题。


<script>
window.onload = function(){
  var box=this.document.getElementsByClassName("re")[0];
  var lik=box.getElementsByTagName("li");
  function fun(i,j){//转换图片函数,就是把透明度改了一下
    lik[i].style.opacity=1;
    lik[j].style.opacity=0;
    lik[i+5].style.backgroundColor="#ffffff";//改一下小图标
    lik[j+5].style.backgroundColor="#00000000"
  }
  fun(0,1);//初始化下
  var i =0;
  function auto(){//轮播循环函数
    if(++i>=5){
      i=0;
      fun(0,4);
    }
    else fun(i,i-1);
  }
  timer=this.setInterval(auto,2000);
  box.onmouseover = function () { //鼠标划上去,停止轮播
    console.log('good');
    clearInterval(timer);
  }
  box.onmouseout = function () { //鼠标划出,继续轮播
    timer = setInterval(auto, 2000); //调用定时器
  }
  var j =0;
  for(;j<5;j++){//点击小图标也可以转换图片
    lik[j+5].ind=j;
    lik[j+5].onclick=function(){
      fun(this.ind,i)
      i=this.ind;
    }
  }

}</script>
<style>
#max{
  width: 900px;
  height: 500px;
  align-items: center;
  margin: 5% auto;
  margin-top: 0%;
  position: absolute;
  left: 190px;
  top: 130px;
}
.re{
  position: relative;
  height: 400px;
}
.re ul{
  list-style-type:none ;
}
.re ul>li{
  width: 600px;
  height: 300px;
  position: absolute;

  transition: 1s;
  opacity: 0;
}
.re ul>li img{
  width: 900px;
  height: 500px;
  border-radius: 10%;
  border: 15px solid #fffbd6;
}
#max ol {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5,75px);
  grid-template-rows: auto;
  grid-gap: 1em;
  float: right;
  margin-top: 450px;
  list-style: none;
  top:0;left:0;
}
#max ol li {
  width: 25px;
  height: 10px;
  font-size: 15px;
  line-height: 20px;
  float: left;
  text-align: center;
  border-radius: 2em;
  border: 5px solid #999999;
}
</style>
<body>
<div id="max">
        <div class="re">
            <ul>
                <li><a href="Fibonacci数列.html"><img src="file:///C|Users/Lenovo/Desktop/数学/图片/我的数学笔记002.png" alt="" title="Fibonacci数列"></a></li>
                <li><a href="Euler常数.html"><img src="file:///C|Users/Lenovo/Desktop/数学/图片/我的数学笔记015.png" alt="" title="Euler常数"></a></li>
                <li><a href="Wallis公式.html"><img src="file:///C|Users/Lenovo/Desktop/数学/图片/我的数学笔记037.png" alt="" title="Wallis公式"</a>></li>
                <li><a href="Newton-Leibniz公式.html"><img src="file:///C|Users/Lenovo/Desktop/数学/图片/我的数学笔记061.png" alt="" title="Newton-Leibniz公式"</a>></li>
                <li><a href="Ceva定理.html"><img src="file:///C|Users/Lenovo/Desktop/数学/图片/我的数学笔记154.png" alt="" title="Ceva定理"></a></li>
            </ul>
            <ol>
                <li></li>
                <li></li>
                <li></li>
                <li></li>
                <li></li>
            </ol>
        </div>
    </div>
</body>

运行结果如下

img

我实在不会了。麻烦大家帮帮我。谢谢。

我希望让图片轮播到那一张就链接到哪一个相应的网页。

  • 写回答

3条回答 默认 最新

  • Null_Reference 2022-05-20 10:49
    关注

    调整一下显示层级

    
    function fun(i,j){//转换图片函数,就是把透明度改了一下
        lik[i].style.opacity=1;
        lik[j].style.opacity=0;
    
       lik[i].style.zIndex=10;
        lik[j].style.zIndex=0;
    
        lik[i+5].style.backgroundColor="#ffffff";//改一下小图标
        lik[j+5].style.backgroundColor="#00000000"
      }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月28日
  • 已采纳回答 5月20日
  • 创建了问题 5月20日

悬赏问题

  • ¥15 MATLAB yalmip gurobi求解器
  • ¥15 关于#stm32#的问题:第一张图是发送数据代码,第二第三张图是接收数据并进行DAC转换的函数,若用串口一接收数据并进行DAC转换,主函数代码该怎么写
  • ¥20 hc130怎么读写内部flash存储信息
  • ¥15 Axure rp9注册与登录交互
  • ¥15 我下载图形界面重启完就变成这样了,打字也打不了,动也动不了,该怎么解决(操作系统-centos)
  • ¥15 VBA中在窗体中遍历所有checkbox控件,提取出被选中的checkbox的caption值
  • ¥15 在Ubuntu上有什么命令,或者是系统文件能告诉我链接nvme ssd的pcie槽位是不是支持热插拔功能?
  • ¥15 ansys license许可证问题
  • ¥20 QQ号和密码都能正常登录微信 QQ号和密码登录微信显示密码错误
  • ¥15 单片机RTOS Kernel与应用分离开发,Kernel如何调起应用?