我们都知道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'){ html" target="_blank">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的实现案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
Window Event: domready 包含窗口'domready'事件,它将被执行当DOM加载完成. 如果某些操作需要确保DOM元素存在,应该把它放在'domready'事件里. 例如: window.addEvent('domready', function() { alert('The DOM is ready!'); });
主要内容:实例:XML 新闻,实例:XML 气象服务如何使用 XML 来交换信息的一些实例。 实例:XML 新闻 XMLNews 是用于交换新闻和其他信息的规范。 对新闻的供求双方来说,通过使用这种标准,可以使各种类型的新闻信息通过不同软硬件以及编程语言进行的制作、接收和存档更加容易: <?xml version="1.0" encoding="ISO-8859-1"?> <nitf> <head> <title>Colombia Earthqua
主要内容:1 案例-Swing实现时钟1 案例-Swing实现时钟 输出结果为:
本文向大家介绍php实现记事本案例,包括了php实现记事本案例的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了php实现记事本的具体代码,供大家参考,具体内容如下 记事本案例 要求:1)页面上有一个文本域(textarea元素),和一个发表按钮 2)用户在文本域中输入内容后,点击发表按钮,会以当天的日期和时间创建一个记事本,并将用户输入的内容保存到记事本中 效果
我正在开发一个有ContentManager类的应用程序。该类从包中迁移文件,并在首次打开应用程序时执行其他检查。接下来,在一个相当长的ViewController链末端的view controller中使用它。据我所知,有两种实现方法: > 在第一个ViewController中实例化类,并将其通过segue传递到最终的ViewController。 在第一个ViewController中创建一
本文向大家介绍实现placeholder效果的方案汇总,包括了实现placeholder效果的方案汇总的使用技巧和注意事项,需要的朋友参考一下 placeholder是html5<input>的一个属性,它提供可描述输入字段预期值的提示信息(hint), 该提示会在输入字段为空时显示。高端浏览器支持此属性(ie10/11在获得焦点时文字消失),ie6/7/8/9则不支持。为了兼容各主流浏览器并使其