判断document加载过程的几个不同方法_html/css_WEB-ITnose

php中文网
发布: 2016-06-24 11:16:18
原创
1424人浏览过

常用的两种页面加载判断方法

1. $(document).ready()

该方法jquery提供的方法,它是当文档结构加载完成时,即形成完整的dom树时(图片和iframe还没有加载完成)触发。其他几种写法:

  • $(function(){});
  • $().ready(function(){})

2. window.onload

该方法表示当页面元素全部加载完成时(包括图片和iframe的加载)触发。在jQuery中有一个同样的方法:$( window ).load(function() {});

3.两种方法的比较

立即学习前端免费学习笔记(深入)”;

当在网页上添加以上两个方法后,当页面加载后控制台输出的结果如下:

立即学习前端免费学习笔记(深入)”;

Html5 中的页面加载方法

1. readystatechange事件

支持该事件的:IE、Firfox4+、Opera支持readystatechange事件的每个对象都有一个readyState属性,该属性有5个值:

  • uninitialized (未初始化) :对象尚未初始化
  • loading (正在加载) :对象正在加载
  • loaded (加载完毕) :对象加载数据完成
  • interactive (交互):可以操作对象,但还没完全加载
  • complete (完成):对象已经加载完毕

并不是所有对象都会经历这五个阶段,readyState属性值也不总是连续的。

在与load事件一起使用时,无法预测两个事件触发的先后顺序。在包含较多或较大的外部资源的页面中,会在load事件触发之前先进入交互阶段;而在包含较少或较小的外部资料的页面中,则很难说readystatechange事件会发生在load事件前面。

运用事例代码:

   document.addEventListener("readystatechange",function(){      if (document.readyState == "complete") {        console.log("readystatechange-complete");       }   });
登录后复制

2. DOMContentLoaded事件

支持该事件的:IE9+、Firefox、Chrome、Safari3.1+、Opera9+

DOMContentLoaded事件在形成完整DOM树之后就会触发,不理会图像、JavaScript文件、CSS文件或其他资源是否已经下载完毕。——《JavaScript高级程序设计》

法语写作助手
法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

法语写作助手 31
查看详情 法语写作助手

想看看该事件与前面两种方法的区别,做了一下测试,在html页面中添加了如下代码:

立即学习前端免费学习笔记(深入)”;

控制台输出结果:

立即学习前端免费学习笔记(深入)”;

由此可以看出DOMContentLoaded事件是在$(document).ready()事件后执行,确实在DOM加载后执行,忽略了图片的加载。但是如果将$(document).ready()写在一个较大的js文件最后,在head中引入到html文件中,最终的控制台输出结果是:

立即学习前端免费学习笔记(深入)”;

这个结果让我觉得DOMContentLoaded并没有忽略JavaScript文件的下载我不知道这么理解是否正确,希望各位大神可以指点一二 ~O(∩_∩)O~

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号