问答详情
源自:9-4 区别getElementByID,getElementsByName,getElementsByTagName

关于变量调用有点不明白

<!DOCTYPE HTML>

<html>

    <head>

        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

        <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">

        // 任务1 

        function checkall(){

            var hobby = document.getElementsByTagName("input");

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

              hobby[i].checked=true;

            }                  

        }

        // 任务2 

        function clearall(){

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

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

              hobby[i].checked=false;

            }      

        }

        

        // 任务3

        function checkone(){

            clearall();

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

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

            // charAt() 方法可返回指定位置的字符。

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

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

                alert("不在范围内,重新输入咯");

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

                //为什么写成上面的可以,用变量指代就不行了...

                // j="";

              }

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

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

              }


            }

        } 

    

    </script>

    </body>

</html>

请教:任务三里的这句,document.getElementById("wb").value=""; 为什么写成 j="";就不起作用了?不是已经把document.getElementById("wb").value赋值给变量j了吗?


我大概明白了。。。 j=""相当于给变量赋了一个新值。。。应该是这样吧?



提问者:二凡 2015-07-27 22:48

个回答

  • arlenhui
    2015-07-28 09:08:26

    变量和对象不一样,一个保存的是值,一个保存的是内存地址,等你以后学习到对象才可以这样使用