自执行js,为什么下面的js获取checkbox的值不执行呢。

<html>
    <head>
        <script type="text/javascript">

            (function() { 
                alert("here.....");
                var ss = document.getElementById("cc").value;
                alert("xxxxx= "+ss);
            })()
        </script>
    </head>

    <body>
        <input type="checkbox" id = "cc" name="c" onclick="getit();" onmouseover="mouseover();" disabled>
    </body>

<html>
阅读 4.4k
1 个回答

因为DOM没有加载完成, 无法读取 value .

解决方法:

  • script 标签放底部
  • 使用 jQuery ready()
  • 挂载到 onload 事件

DEMO:

<html>
<head>
  <script>
    alert("here.....");
    window.onload = function() { 
      var a = document.getElementById("cc").value;
      alert("xxxxx= "+a);
    }
  </script>
</head>
<body>
  <input type="checkbox" id="cc">
</body>
<html>
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题