文档的加载顺序

本文探讨了浏览器加载HTML页面时JavaScript的执行顺序问题。由于JavaScript是解释型语言,浏览器会自上而下解析。当<script>标签位于页面顶部时,可能会因对象未定义导致错误。解决方案包括将JS代码移至<body>标签后或利用window.onload事件确保页面加载完毕后再执行JS。这两种方法能确保在正确的时间执行JavaScript,避免因页面元素未加载完成而引发的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

浏览器在加载一个页面时,是按照自上向下的顺序加载的,读取一行运行一行(解释型语言的特点)。

如果将script标签写到页面的上边,就会先执行<script>,再执行<body>,所以如果执行到script时调用 doument中创建的对象,就会出错,因为对象还没定义,所以有两种解决办法:

  • 将JS代码编写到 <body>后面
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
  </head>
  <body>
    <button id="btn">按钮</button>
      <script>
       console.log(document);

      // 获取对象
      var btn = document.getElementById("btn");

      // 给对象添加属性,并赋值(绑定处理函数)
      // 这样当对应的事件触发时,的时候就执行相对应的函数
      btn.onclick = function(){
        alert("你点我干啥");
      }
      // 像这种为单击事件绑定的函数,我们称为单击响应函数

    </script>
   
  </body>
</html>

  • 设置函数使页面加载完成之后才执行JS函数
    思路:
    页面加载完成也是一个事件,也可以设置执行函数。
    所以我们可以将所有的JS代码都写到页面加载完成这个事件的执行函数中即可。

加载完成事件onload 事件
onload 事件会在页面或图像加载完成后立即发生。

onload对应的对象是window

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <script>
      window.onload = function () {
        console.log(document);
        var btn = document.getElementById("btn");

        btn.onclick = function () {
          alert("你点我干啥");
        };
      };
    </script>
  </head>
  <body>
    <button id="btn">按钮</button>
  </body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值