猿问

第48-51这个for循环的内容不太懂?

这段代码主要实现在文本框内输入 上面6个爱好的对应的1-6的序号,可以将其打钩选中,可是我理解他怎么觉得他吧1-j(即输入的数字)之间的的爱好全选中了?可事实证明我的理解是错的

<!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;

           }

        }

        function clearall(){

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

            for(var i=0;i<hobby.length;i++){

                hobby[i].checked=false;

            }

        }

        

      

        function checkone(){

            clearall();

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

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

            for(var i=0;i<j.length;i++){

                if(j.charAt(i)>6 || j.charAt(i)<1){

                    alert("越界,请重新输入!");

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

                }

            }

                for(var n=0;n<j.length;n++){

                   

                        hobby[(j.charAt(n))-1].checked=true; 

                }


            

            

        }

        

        </script>

    </body>

</html>

想要飞的鱼儿
浏览 1183回答 2
2回答

qq_青枣工作室_0

他这个是多选的,所以你文本框里可以填写123456表示全选,填写123表示选择前面三个。那最后一个for循环就是把你填写的123456里的每一个数字对应的复选框选中。他要把你输入的每个字符都遍历一次。

想要飞的鱼儿

也就是最后一个函数的最后一个for循环
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答