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){ 'usestrict'; vardocument=win.document, readList=[],//等待执行的函数堆栈 flag=false; varremoveEvent=function(){ if(document.addEventListenner){ window.removeEventListenner('load',handle,false); }elseif(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会使用最短时间,该时间不同系统并不一样。 }elseif(document.addEventListenner){ document.addEventListenner('DOMContentLoaded',fn,false); window.addEventListenner('load',handle,false); }elseif(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=(newDate().getTime()-date)/1000; });
以上这篇domReady的实现案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。