为了账号安全,请及时绑定邮箱和手机立即绑定

我这个输入2为什么也会出现他弹窗?

帮忙看看

<!DOCTYPE HTML>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
        <title>无标题文档</title>
    </head>
    
    <body>
        <form>
          请选择你爱好:<br>
          <input type="checkbox" name="hobby" id="hobby1">  音乐
          <input type="checkbox" name="hobby" id="hobby2">  登山
          <input type="checkbox" name="hobby" id="hobby3">  游泳
          <input type="checkbox" name="hobby" id="hobby4">  阅读
          <input type="checkbox" name="hobby" id="hobby5">  打球
          <input type="checkbox" name="hobby" id="hobby6">  跑步 <br>
          <input type="button" value = "全选" onclick = "checkall();">
          <input type="button" value = "全不选" onclick = "clearall();">
          <p>请输入您要选择爱好的序号,序号为1-6:</p>
          <input id="wb" name="wb" type="text" >
          <input name="ok" type="button" value="确定" onclick = "checkone();">
        </form>
        <script type="text/javascript">
        function checkall(){
            var hobby = document.getElementsByTagName("input");
           for(var i=0;i<hobby.length;i++){
               hobby[i].checked=true;
           }
          // 任务1 
           
        }
        function clearall(){
            var hobby = document.getElementsByName("hobby");
           for(var i=0;i<hobby.length;i++){
               hobby[i].checked=false;
           } 
         // 任务2    
            
        }
        
        function checkone(){
            var j=document.getElementById("wb").value;
            var hobby = document.getElementsByName("hobby");
        for(var k=0;k<hobby.length;k++){
            if(k==j-1){
                hobby[k].checked=true;
            }else{
                alert("请输入1-6的数");
            }
            break;
        }
         // 任务3
        
        }
        
        </script>
    </body>
</html>


正在回答

1 回答

问题出在最后一个函数checkone里的for循环中,

 if(k==j-1){

                hobby[k].checked=true;

            }else{

                alert("请输入1-6的数");

            }

你可以想想当输入j=5,循环开始时k=0这时if(k==j-1)中 0!=4执行else中的alert当然会弹出窗口啦,建议修改如下:

       function checkone(){

        var j=document.getElementById("wb").value;

        var hobby = document.getElementsByName("hobby");

        if(j<=hobby.length)

        {

        hobby[j-1].checked=true;

        }

        else

        {

            alert("another number");

        }

        }

 

1 回复 有任何疑惑可以回复我~
#1

我要学习js 提问者

非常感谢!
2016-04-05 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

我这个输入2为什么也会出现他弹窗?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信