JS点击事件——Uncaught TypeError: Cannot set property 'onclick' of null

html代码:

<body>
    <button id="button">点击我</button>
    <img id="image" src="cat.png" width="100px">
</body>

JS代码:

<script>
    var button = document.getElementById("button"),
        image = document.getElementById("image");

    button.onclick = function () {
        image.style.display = "none";
    };
</script> 

需要实现的效果:单击button按钮时image消失。

我的做法:相关代码如上面所示,把js代码放在<head>中,于是报错Uncaught TypeError: Cannot set property 'onclick' of null。

改进做法:把JS代码放到</body>结束之前,完美实现。

提问:为什么会出现这种情况?是不是与JS代码的执行顺序有关。

解答:通过查阅一些资料,了解到放在<head>中的JS代码是优先于页面被执行的:

来源:点击打开链接

另一种方法也可达到目的:把原本的JS代码放入window.οnlοad=function() { ... }中,window.onload表示页面加载完成后执行的函数,这样JS代码即使放在<head>中也可以完美实现效果。

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值