文档的加载顺序

本文探讨了浏览器加载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>

### Spring Boot 配置文件加载顺序 Spring Boot 的配置文件加载机制遵循一定的优先级规则,这些规则决定了哪些配置会覆盖其他配置。以下是关于 Spring Boot 配置文件加载顺序的详细介绍: #### 默认配置文件加载顺序 Spring Boot 使用 `ConfigFileApplicationListener` 来处理外部化配置文件加载过程。默认情况下,它按照以下顺序加载配置文件[^1]: 1. **命令行参数 (Command Line Arguments)** 命令行参数具有最高优先级,可以覆盖任何其他地方定义的属性。 2. **来自 Java System Properties 的属性** 这些可以通过 `-Dproperty=value` 形式传递给 JVM。 3. **操作系统环境变量** 环境变量也可以作为配置的一部分被读取。 4. **随机数生成器中的 random.* 属性** 如果应用程序需要一些动态生成的值(如端口),可以从这里获取。 5. **servlet-config 和 servlet-context 初始化参数** 当运行于 Servlet 容器中时,初始化参数会被考虑进来。 6. **JNDI 属性 (java:comp/env/)** JNDI 提供了一种标准的方式来访问企业级别的资源和服务。 7. **Java 资源路径下的 application.properties 或者 application.yml 文件** 包括 classpath:/, classpath:/config/, file:./, file:./config/ 中的内容都会被扫描并应用。 8. **打包 jar 外部的应用程序包外的 profile-specific properties 文件** 例如:application-dev.properties。 9. **打包 jar 内部的应用程序包内的 profile-specific properties 文件** 同样支持基于不同 profiles 的定制化设置。 10. **打包 jar 外部的应用程序包外的基础 properties 文件** 如 application.properties 或 application.yml。 11. **打包 jar 内部的应用程序包内的基础 properties 文件** 即位于 resources 下的标准配置文件。 上述列表展示了从高到低的不同层次上的配置来源及其相对应的作用范围和影响程度[^3]。 #### 自定义 MyBatis 配置的影响 如果项目引入了 MyBatis 并通过其自动配置功能,则可能会涉及到额外的自定义配置项。比如,在 org.mybatis.spring.boot.autoconfigure.MybatisProperties 类中定义了一些特定的关键字用于描述数据库连接池大小、SQL 映射位置等细节[^2]。这类扩展不会改变整体框架对于全局配置文件解析逻辑的行为模式,但它确实增加了局部领域内可调整选项的数量。 ```yaml mybatis: config-location: classpath:mybatis/mybatis-config.xml mapper-locations: classpath:mappers/**/*.xml ``` 以上是一个典型的 YAML 片段例子展示如何指定 MyBatis XML 文件的位置以及主配置文档地址。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值