我们都知道JQ的 $(document).ready(fn) 方法。可以在页面准备就绪后才执行脚本,该方法相比传统的window.onload 事件,它的优势体现于onload事件是需要等到页面中所有资源都加载完毕后才会触发,而JQ的ready方法则会判断DOM树是否构建完毕。

  onload相比较onreadystate事件的区别是,onreadystatechange事件是IE独有的,并且在IE11之后不再支持,该事件是IE浏览器为特定的需要判断资源加载的DOM元素指定的事件。
支持onreadystatechange事件的DOM元素必然有一个readyState属性,该属性的返回值,用于说明资源的加载情况。
一般而言,onreadystatechange事件更多用于Iframe的加载判断。

  最后我们需要了解的是当页面包含iframe后,DOM树的生成,以及DOMContentLoaded事件的触发,onload事件的触发,其流程对于IE非IE是不同的。
一般来说:
    IE :解析index页面 -> 解析iframe页面 -> 触发iframe的DOMContentLoaded事件 -> 触发iframe页面 onload事件 -> 触发Index页面的DOMContentLoaded事件 -> 触发index页面的onload事件。
    !IE : 解析index页面 -> 触发index页面的DOMContentLoaded事件 -> 解析iframe页面 -> 触发iframe页面的DOMContentLoaded事件 -> 触发iframe的onload事件 -> 触发index页面的onload事件。
  从这个流程,我们可以看出IE中,必须等待当前页面的iframe加载解析完毕,当前页面才能加载解析完毕,而在非IE中,iframe的加载与解析对当前页面来言更多的是异步执行。

  下面是具体的代码:

  

 (function(win){

     'use strict';

     var document = win.document,
readList = [], // 等待执行的函数堆栈
flag = false; var removeEvent = function(){ if(document.addEventListenner){
window.removeEventListenner('load',handle,false);
}else if(document.attachEvent){
window.detachEvent('onload',handle)
document.detachEvent('onreadystatechange',readyState);
}else{
window.onload = null;
} },
handle = function(){ if(!flag){ while(readList.length){
readList[0].call(); //执行函数
readList.shift(); //删除第一个数组元素
}
flag = true;
removeEvent();
} },
readyState = function(){
if(document.readyState == 'complete'){
handle();
}
},
DOMContentloaded=function(){ if(document.readyState == 'complete'){
setTimeout(handle); // setTimeout 会使用最短时间,该时间不同系统并不一样。
}else if(document.addEventListenner){
document.addEventListenner('DOMContentLoaded',fn,false);
window.addEventListenner('load',handle,false);
}else if(document.attachEvent){
window.attachEvent('onload',handle);
document.attachEvent('onreadystatechange',readyState); //onreadystatechange 事件在页面中含有iframe的时候,它会等待iframe加载完毕才会触发。 if(self === self.top){ // 当页面不在iframe中则使用此种方式检测doScroll方法是否可用。如果再iframe中则用onreadstatechange事件进行判断。
(function(){
try{
document.documentElement.doScroll('left');
}catch(e){
setTimeout(arguments.callee,50); //arguments.callee 是对当前函数的引用。
return ;
}
handle();
}());
} }else{
window.onload = handle;
}
},
ready = function(fn){
readList.push(fn); // 加入待处理的堆栈中。
DOMContentloaded();
}; win.domReady = ready; }(window));

代码调用:

 domReady(function(){
document.getElementById('box').innerHTML = (new Date().getTime() - date)/1000;
});

最新文章

  1. .NET面试题目
  2. HTML的 <u> 标签
  3. mysql - 其它
  4. 十进制转为N进制
  5. [WP8.1UI控件编程]Windows Phone理解和运用ItemTemplate、ContentTemplate和DataTemplate
  6. 如何从Win7中提取制作Windows PE3.0
  7. JavaWeb学习总结(一)——JavaWeb开发入门(转载)
  8. Delphi-Copy 函数
  9. 简易的WPF MVVM模式开发
  10. java利用url实现网页内容的抓取
  11. Opengl4.5 中文手册—G
  12. Windows环境下安装Oracle数据库
  13. 手机移动端input date placehoder不显示
  14. 如何快速上手一个新技术之vue学习经验
  15. 在IIS7里配置 ISAPI,运行dll程序,总提示下载dll
  16. 《Java并发编程实战》笔记-synchronized和ReentrantLock
  17. 常用官方php版本下载链接
  18. WordPress主题开发:开启文章缩略图功能
  19. poj1850Code
  20. Extending Conductor

热门文章

  1. (JS+CSS)实现图片放大效果
  2. Android 获取系统相册中的所有图片
  3. CoreCRM 开发实录——Travis-CI 实现 .NET Core 程度在 macOS 上的构建和测试 [无水干货]
  4. XML技术之DOM4J解析器
  5. nginx源码分析之模块初始化
  6. 使用ubuntu作为web开发环境的一些感受
  7. 微软发布VSBT,无需安装Visual Studio即可实现项目编译
  8. Java列表
  9. BPM SharePoint解决方案分享
  10. 【iOS10 SpeechRecognition】语音识别 现说现译的最佳实践