提取jQuery.ready(),页面DOM原生加载完毕执行onDOMReady()
2010-12-13 11:05
429 查看
在大部分前端开发中,需要在DOM树载入时马上执行一些函数,但又不愿意仅为了这一个需求而引入整个jQuery库,于是就把jQuery的ready方法提取出来,单独使用了。
当然大家可以使用windows.onload事件, 但onload在浏览器看来,就是页面上的东西(img,iframe等资源)全部都加载完毕后才能发生,
如果页面内有大的图片的话,会在页面展现后好久时间后才执行。
如果只需要对DOM进行操作,那么这时就没必要等到页面全部加载了。我们需要更快的方法。
Firefox有DOMContentLoaded事件可以轻松解决,可惜的就是IE没有。
MSDN关于JSCRIPT的一个方法有段不起眼的话,当页面DOM未加载完成时,调用doScroll方法时,会产生异常。
那么我们反过来用,如果不异常,那么就是页面DOM加载完毕了!
所以 对于Mozilla & Opera 浏览器,在dom树载入后有现成的 DOMContentLoaded 事件
对于Safari 浏览器,有document.onreadystatechange事件,
当该事件触发时,如果 document.readyState=complete时,可视为dom树已经载入
对于ie,当在iframe内时,同样有document.onreadystatechange事件,
对于ie在非iframe内时,只有不断地通过能否执行doScroll判断dom是否加载完毕。
在本例中每间隔5毫秒尝试去执行 document.documentElement.doScroll('left')
另外要注意一点:在ie8下,貌视非iframe窗口也会有document.onreadystatechange事件,另外你也可以在构建自己的JS框架时使用此函数.
使用方法如下:
当然大家可以使用windows.onload事件, 但onload在浏览器看来,就是页面上的东西(img,iframe等资源)全部都加载完毕后才能发生,
如果页面内有大的图片的话,会在页面展现后好久时间后才执行。
如果只需要对DOM进行操作,那么这时就没必要等到页面全部加载了。我们需要更快的方法。
Firefox有DOMContentLoaded事件可以轻松解决,可惜的就是IE没有。
MSDN关于JSCRIPT的一个方法有段不起眼的话,当页面DOM未加载完成时,调用doScroll方法时,会产生异常。
那么我们反过来用,如果不异常,那么就是页面DOM加载完毕了!
所以 对于Mozilla & Opera 浏览器,在dom树载入后有现成的 DOMContentLoaded 事件
对于Safari 浏览器,有document.onreadystatechange事件,
当该事件触发时,如果 document.readyState=complete时,可视为dom树已经载入
对于ie,当在iframe内时,同样有document.onreadystatechange事件,
对于ie在非iframe内时,只有不断地通过能否执行doScroll判断dom是否加载完毕。
在本例中每间隔5毫秒尝试去执行 document.documentElement.doScroll('left')
另外要注意一点:在ie8下,貌视非iframe窗口也会有document.onreadystatechange事件,另外你也可以在构建自己的JS框架时使用此函数.
(function(){ var isReady=false; //判断onDOMReady方法是否已经被执行过 var readyList= [];//把需要执行的方法先暂存在这个数组里 var timer;//定时器句柄 ready=function(fn) { if (isReady ) fn.call( document); else readyList.push( function() { return fn.call(this);}); return this; } var onDOMReady=function(){ for(var i=0;i<readyList.length;i++){ readyList[i].apply(document); } readyList = null; } var bindReady = function(evt){ if(isReady) return; isReady=true; onDOMReady.call(window); if(document.removeEventListener){ document.removeEventListener("DOMContentLoaded", bindReady, false); }else if(document.attachEvent){ document.detachEvent("onreadystatechange", bindReady); if(window == window.top){ clearInterval(timer); timer = null; } } }; if(document.addEventListener){ document.addEventListener("DOMContentLoaded", bindReady, false); }else if(document.attachEvent){ document.attachEvent("onreadystatechange", function(){ if((/loaded|complete/).test(document.readyState)) bindReady(); }); if(window == window.top){ timer = setInterval(function(){ try{ isReady||document.documentElement.doScroll('left');//在IE下用能否执行doScroll判断 dom是否加载完毕 }catch(e){ return; } bindReady(); },5); } } })();
使用方法如下:
ready(dosomething);//dosomething为已存在的函数 //也可以通过闭包来使用 ready(function(){ //这里是逻辑代码 });
相关文章推荐
- 怎样提取jQuery.ready(),DOM加载完毕执行onDOMReady()方法
- 你真的了解jQuery的ready函数吗?当 DOM(文档对象模型) 已经加载,就执行ready里的代码。DOM何时加载完毕?jQuery对html局部操作,DOM为什么不重新加载?
- 页面自动执行的几种方法 (加载)js的几种方法 原生和jquery
- jQuery DOMready 页面加载事件 研究
- jQuery页面加载时触发ready()事件 dom结构加载完成就触发。(参考慕课网)
- js在页面中的加载顺序及多个jquery $(document).ready() 的执行顺序
- jQuery DOMready 页面加载事件 研究
- jQuery参考实例 1.2 在DOM加载完毕,页面元素完全加载之前运行jQuery/JavaScript代码
- jquery加载页面的方法(页面加载完成就执行)
- Jquery 在页面加载后执行的几种方式
- jquery页面加载响应事件$(document).ready()与js页面加载响应事件window.onload()的区别
- 页面加载完毕后执行一段脚本
- 使用jquery当页面打开时,将一个事件绑定到控件(同时执行两个事件),并修改加载样式类中的样式
- Jquery 在页面加载后执行的几种方式
- jquery加载页面的方法(页面加载完成就执行)
- 【JQuery】页面加载时触发ready()事件
- jquery加载页面的方法(页面加载完成就执行)
- js在html中的加载执行顺序,多个jquery ready执行顺序
- 原生JS与jQuery文档加载完毕的写法
- Jquery和js的页面加载完成执行的几种方式和区别