您好,欢迎访问一九零五行业门户网

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的加载与解析对当前页面来言更多的是异步执行。
下面是具体的代码:
(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; });
以上这篇domready的实现案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
更多domready的实现案例。
其它类似信息

推荐信息