爱法斗学编程 2019-12-07 16:35 采纳率: 72.7%
浏览 640
已采纳

js二级菜单问题,显示一个,不显示其他二级菜单

代码请看下面,我这个是看了课本的案例后,仿着写的,后面对比了好几遍,
都没差异的,但是就是不能解决问题。只能点第三个才出现,点前两个不出现。
还请不要介绍奇特方法,其他方法我已实现,只是这个是课本上的原句,我实在不解为何
不行,还请懂得朋友给予解答。

<ul id="ul_1">
            <li class="li_yi" onmouseover="forErji(0);"><a href="http://www.baidu.com" target="_blank" >百度</a></li>
            <li class="li_yi" onmouseover="forErji(1);"><a href="http://www.sina.com" target="_blank" >新浪</a></li>
            <li class="li_yi" onmouseover="forErji(2);"><a href="http://www.sohu.com" target="_blank" >搜狐</a></li>
            <li class="li_yi"><a href="http://www.jd.com" target="_blank">京东</a></li>
            <li class="li_yi"><a href="http://www.suning.com" target="_blank">苏宁</a></li>
        </ul>
<script type="text/javascript">
        var temp=document.getElementsByClassName("er_div")
        function forErji(num)
        {
            var i=0;
            while(i<=2){
                if (i==num) {temp[num].style.display="block";}
              else{temp[num].style.display="none";}
              i++;
            }
        }
    </script>

我只写了前三个有二级菜单,但是现在由于这个while循环的存在(改成for循环也不行),只有点第三个一级菜单新浪才出现,点前两个一级菜单是没反应的

  • 写回答

3条回答 默认 最新

  • threenewbee 2019-12-07 17:16
    关注
                    if (i==num) {temp[i].style.display="block";}
                  else{temp[i].style.display="none";}
                是i不是num
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器