问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

怎么用bower安装domReady

发布网友 发布时间:2022-05-16 06:12

我来回答

2个回答

懂视网 时间:2022-05-16 10:33

我们都知道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中文网!

热心网友 时间:2022-05-16 07:41

一、为什么要用require.js?
最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了。后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载。下面的网页代码,相信很多人都见过。
  <script src="1.js"></script>
  <script src="2.js"></script>
  <script src="3.js"></script>
  <script src="4.js"></script>
  <script src="5.js"></script>
  <script src="6.js"></script>
这段代码依次加载多个js文件。
这样的写法有很大的缺点。首先,加载的时候,浏览器会停止网页渲染,加载文件越多,网页失去响应的时间就会越长;其次,由于js文件之间存在依赖关系,因此必须严格保证加载顺序(比如上例的1.js要在2.js的前面),依赖性最大的模块一定要放到最后加载,当依赖关系很复杂的时候,代码的编写和维护都会变得困难。
require.js的诞生,就是为了解决这两个问题:
如果你对这个答案有什么疑问,请追问,
另外如果你觉得我的回答对你有所帮助,请千万别忘记采纳哟!
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
鞋底是空心格子怎么办 鞋里有格子硌脚怎么办 买的鞋子里面是空心格子底硌脚怎么办 鞋子底是空心格子的怎样办 浅谈NY5196—2002有机茶 有机食品茶叶标准 茶叶的储藏运销:茶叶贮藏期的化学变化 东方美人茶要怎么储存?东方美人茶储存方法 乌龙茶贮运方法 有机乌龙茶是什么贮藏与运输的? 含笔的成语有哪些 包含笔的成语有哪些 笔的成语有哪些成语 有笔的四字成语 带笔的成语有那些 文艺复兴、启蒙运动、法国、英国、美国大*的时间能帮我排列并讲述一下吗?老是弄混,谢谢 第二次世界大战以后,新艺术的中心有了怎样的改变? 从文艺复兴到一系列大事二战的内在关系 会不会在可预见的未来出现第二次文艺复兴? 第二次文艺复兴是什么时候 第二次文艺复兴是指什么 说的具体点 怎么办理遗赠扶养协议公证 遗赠协议公证应注意什么事项? 办理遗赠扶养协议公证的条件有哪些 遗赠抚养协议公证怎么做 我爱你 爱到恨我自己 我恨你 也很不相信 是一首歌的最后两句 是个女的唱的 可是我记不住名字 我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我恨你!我 办理遗赠抚养协议公证要注意什么 办理遗赠扶养协议应当提交哪些材料 阿信有首歌歌词有句我恨你,恨自己太爱你,那首歌叫什么? 男婚前贷款买房,他已经已经还清了贷款,也装修完毕,女方一分钱没出,女方想婚后加上名字,这要求过分吗 dojo/domready,什么意思 document ready是个什么函数 会计跟岗心得.ppt 如何培养学生的情感态度与价值观 mootools 多个domready事件冲突了,怎么办? 哪里能找到执业药师啊 请问有什么好的方法看到江苏各省的药师招聘信息,驻店药师都行。 但要可靠。有的告诉下, 招聘药剂师前十名企业 我是一名执业药师,如果需要挂靠或者是寻求兼职的,在哪挂比较好! 福建厦门招聘药师中药师哪里可以发布 哪里招中药剂师? 有执业证书,中医药大学专科毕业,女, 工作经验6年多。 药剂师面试 我要开药店,那里可以找到有“药剂师”证有人。 名字 姓谢 女宝宝 有内涵的名字 菽水承欢,贫士养亲之乐;义方是训,父亲教子之严。怎么解释 菽水承欢 帮忙取个宝宝名字。。。姓谢,要三个字的 男、女都要好听的。。。多谢了! 椒水承欢是什麼意思,出于何典? 孝敬老人的成语