最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

domReady的实现案例

来源:动视网 责编:小采 时间:2020-11-27 20:27:09
文档

domReady的实现案例

domReady的实现案例:我们都知道JQ的 $(document).ready(fn) 方法。可以在页面准备就绪后才执行脚本,该方法相比传统的window.onload 事件,它的优势体现于onload事件是需要等到页面中所有资源都加载完毕后才会触发,而JQ的ready方法则会判断DOM树是否构建完毕。onload
推荐度:
导读domReady的实现案例:我们都知道JQ的 $(document).ready(fn) 方法。可以在页面准备就绪后才执行脚本,该方法相比传统的window.onload 事件,它的优势体现于onload事件是需要等到页面中所有资源都加载完毕后才会触发,而JQ的ready方法则会判断DOM树是否构建完毕。onload

我们都知道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的实现案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持PHP中文网。

更多domReady的实现案例相关文章请关注PHP中文网!

文档

domReady的实现案例

domReady的实现案例:我们都知道JQ的 $(document).ready(fn) 方法。可以在页面准备就绪后才执行脚本,该方法相比传统的window.onload 事件,它的优势体现于onload事件是需要等到页面中所有资源都加载完毕后才会触发,而JQ的ready方法则会判断DOM树是否构建完毕。onload
推荐度:
标签: 实现 案例 实例
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top