首页 > Web开发 > 详细

JS事件报错之Cannot set property 'onclick' of null

时间:2019-08-13 11:09:08      阅读:62      评论:0      收藏:0      [点我收藏+]
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <script>
            //根据id属性的值从文档中获取这个元素
            var btnObj=document.getElementById("btn");
            //为当前的这个按钮元素(对象),注册点击事件,添加事件处理函数    (匿名函数)
            btnObj.onclick=function(){
                //响应做的事情
                alert("jaja");
            };
        </script>
    </head>
    <body>
        <input type="button" value="显示效果" id="btn" />    
    </body>
</html>

上面代码执行后,显示

技术分享图片

进行更改,需要把js文件放在底部加载:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>    
    </head>
    <body>
        <input type="button" value="显示效果" id="btn" />    
        <script>
            //根据id属性的值从文档中获取这个元素
            var btnObj=document.getElementById("btn");
            //为当前的这个按钮元素(对象),注册点击事件,添加事件处理函数    (匿名函数)
            btnObj.onclick=function(){
                //响应做的事情
                alert("jaja");
            };
        </script>
    </body>
</html>

代码正常执行

原因:当js文件放在head里面时,如果绑定了onclick或者onmouseover事件,就会出现如上图类似的错误,是因为浏览器的加载你写的html文档的顺序是从上往下,加载完按钮节点才执行的js,所以当浏览器自顶向下解析时,找不到onclick绑定的按钮节点,于是报错。

解决办法:第一,把js文件放在底部加载;第二,使用window.onload=function(){}包裹js内容。

 

JS事件报错之Cannot set property 'onclick' of null

原文:https://www.cnblogs.com/zhangDY/p/11344502.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!