load、$(document).ready、DOMContentLoaded的区别

简介: load、$(document).ready、DOMContentLoaded的区别

load$(document).readyDOMContentLoaded 是用于处理页面加载和文档准备就绪的事件和方法。它们有以下区别:

  1. load 事件:load 事件在整个页面及其所有外部资源(如图像、样式表、脚本等)都加载完成后触发。可以通过 JavaScript 或 jQuery 来监听 load 事件,例如:

    window.addEventListener('load', function() {
         
      // 页面和所有资源加载完成后执行的代码
    });
    
    $(window).on('load', function() {
         
      // 页面和所有资源加载完成后执行的代码
    });
    

    load 事件适用于在页面完全加载后执行一些操作,例如处理图像的尺寸、启动动画效果等。

  2. $(document).ready(又称为 jQuery 的 DOM 就绪事件):$(document).ready 是 jQuery 提供的方法,它在文档结构准备完毕并可以操作时触发。它表示 DOM 已经解析完毕,但可能仍在等待外部资源的加载完成。可以使用以下方式监听 $(document).ready 事件:

    $(document).ready(function() {
         
      // DOM 准备就绪后执行的代码
    });
    

    或者使用简化的写法:

    $(function() {
         
      // DOM 准备就绪后执行的代码
    });
    

    $(document).ready 事件适用于在 DOM 解析完毕后执行一些操作,例如绑定事件处理程序、修改 DOM 元素等。需要注意的是,现代版本的 jQuery 已经对 $(document).ready 进行了优化,使其在大多数情况下不再需要显式调用。

  3. DOMContentLoaded 事件:DOMContentLoaded 事件是原生 JavaScript 提供的事件,当整个 HTML 文档被解析并转化为 DOM 树时触发。可以使用以下方式监听 DOMContentLoaded 事件:

    document.addEventListener('DOMContentLoaded', function() {
         
      // DOM 准备就绪后执行的代码
    });
    

    DOMContentLoaded 事件与 $(document).ready 事件类似,表示 DOM 结构已经准备好,可以进行操作。但与 $(document).ready 不同,DOMContentLoaded 是原生 JavaScript 的事件,不依赖于任何库或框架。

总结来说,load 事件在整个页面和资源加载完成后触发,$(document).ready 事件在 DOM 结构准备就绪后触发(使用 jQuery),而 DOMContentLoaded 事件在 DOM 解析完成后触发(原生 JavaScript)。

注意:在使用 load 事件或 $(document).ready 事件时,确保它们在实际需要时才被触发,以避免不必要的延迟。而 DOMContentLoaded 事件是一个原生事件,无需担心触发时机的问题。

相关文章
|
资源调度 前端开发 JavaScript
Bootstrap日期选择器插件bootstrap-datepicker
Bootstrap日期选择器插件bootstrap-datepicker
1371 12
|
Linux C++ iOS开发
vs code常见的查找快捷键大全
本文来自 frozencola 技术日志,介绍了 VS Code 中常用的查找快捷键,包括快速打开文件、文件资源管理器、全局搜索、查找符号、查找文件中的文本、查找并替换、文件导航和使用命令面板。掌握这些快捷键可以显著提升开发效率。
1575 4
ES5/ES6 的继承除了写法以外还有什么区别
ES5 和 ES6 的继承主要区别在于实现机制和语法糖。ES5 通过原型链和构造函数模拟类的继承,而 ES6 引入了 class 关键字,使继承更加直观和简洁,支持 super 调用父类方法,提升了代码可读性和维护性。
|
缓存 JavaScript 前端开发
WebView完全解读
WebView完全解读
1282 133
|
小程序 JavaScript
微信小程序之input组件及其获取用户输入信息
微信小程序之input组件及其获取用户输入信息
389 2
|
设计模式 前端开发 Java
DDD建模系列(五)
DDD建模系列(五)
|
大数据 PHP 数据库
深入理解PHP中的生成器(Generators)
【7月更文挑战第17天】在PHP开发中,生成器是一个强大但常被忽视的特性,它允许开发者以迭代器的方式处理大量数据而不需要一次性将所有数据加载到内存。本文将介绍生成器的基本概念、使用场景和实现方法,帮助读者掌握如何利用生成器优化程序性能和提高代码的可读性与维护性。
|
开发者 Python
在Python中查询进程信息的实用指南
在Python中查询进程信息的实用指南
740 2
|
开发框架 .NET API
.NET Core 和 .NET 标准类库项目类型有什么区别?
在 Visual Studio 中,可创建三种类库:.NET Framework、.NET Standard 和 .NET Core。.NET Standard 是规范,确保跨.NET实现的API一致性,适用于代码共享。.NET Framework 用于特定技术,如旧版支持。.NET Core 库允许访问更多API但限制兼容性。选择取决于兼容性和所需API:需要广泛兼容性时用.NET Standard,需要更多API时用.NET Core。.NET Standard 替代了 PCL,促进多平台共享代码。
332 0

热门文章

最新文章