JavaScript 控制台报错 Cannot set property 'innerHTML' of null

问题:通过 document.innerHTML 改变 id="p1" 标签中的内容,代码如下。

          在浏览器中打开,控制台报错:“innerHTML属性为空”。

         

        

原因:在一个HTML文档中,javascript代码属于 通过作为标签引入的脚本,属于HTML的组成部分。

          浏览器按照 从上至下的文档执行顺序 解析页面结构。

          执行document.getElementById("p1").innerHTML = person.fullName();时,<p>标签还不存在。

解决方案:

         1.通过 window.onload 控制加载完页面后执行。

         

         2. <script>代码块放在<p>标签的后面。

         

其他:window.onload 和 jQuery中的$(document).ready的区别

         window.onload 需要等待页面元素全部加载完成 才能开始执行;

         $(document).ready 在DOM结构绘制完毕 就可以开始执行。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值