domReady的实现案例

前端之家收集整理的这篇文章主要介绍了domReady的实现案例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我们都知道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的加载与解析对当前页面来言更多的是异步执行。

下面是具体的代码

'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();  //执行<a href="https://www.jb51.cc/tag/hanshu/" target="_blank" class="keywords">函数</a>
    readList.shift();  //<a href="https://www.jb51.cc/tag/shanchu/" target="_blank" class="keywords">删除</a>第一个数组元素
  }
  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',false);
}else if(document.attachEvent){
  window.attachEvent('onload',handle);
  document.attachEvent('onreadystatechange',readyState);  //onreadystatechange 事件在<a href="https://www.jb51.cc/tag/yemian/" target="_blank" class="keywords">页面</a>中含有iframe的时候,它会等待iframe加载完毕才会触发。

  if(self === self.top){  // 当<a href="https://www.jb51.cc/tag/yemian/" target="_blank" class="keywords">页面</a>不在iframe中则使用此种方式检测doScroll<a href="https://www.jb51.cc/tag/fangfa/" target="_blank" class="keywords">方法</a>是否可用。如果再iframe中则用onreadstatechange事件进行判断。
    (function(){
      try{
        document.documentElement.doScroll('left');
      }catch(e){
        setTimeout(arguments.callee,50);  //arguments.callee 是对当前<a href="https://www.jb51.cc/tag/hanshu/" target="_blank" class="keywords">函数</a>的引用。
        return ;
      }
      handle();
    }());
  }

}else{
  window.onload = handle;
}

},ready = function(fn){
readList.push(fn); // 加入待处理的堆栈中。
DOMContentloaded();
};

win.domReady = ready;

}(window));

代码调用

Box').innerHTML = (new Date().getTime() - date)/1000; });

以上这篇domReady的实现案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

原文链接:https://www.f2er.com/js/44252.html

猜你在找的JavaScript相关文章