对于很多初学者来说,window.onload出现在代码中的频率非常高,这似乎变成了一种习惯,可是并不知道具体为什么要加这句代码,可以做几个试验对比:

实验一:

<script>

  document.getElementById("me").style.color = "blue";

</script>

<body>

  <h1 id="me">大宝章 is Double Zhang</h1>

</body>

实验结果是 h1字体为原始黑色,并没有被渲染为蓝色,原因是document文档是从上向下解析执行,当执行到script时,body中的h1还未被执行和加载到网页中,这时候 document.getElementById("me") 并没有获取到h1对象,就更不存在将它的字体设置为蓝色了。

------------------------------------------------------------------------------------------------------------

实验二:

<body>

  <script>

    document.getElementById("me").style.color = "blue";

  </script>

  <h1 id="me">大宝章 is Double Zhang</h1>

</body>

实验结果字体为原始的黑色,可以很好的解释“document文档是从上向下解析执行”,当执行script时,h1仍旧没有被加载。

------------------------------------------------------------------------------------------------------------

实验三:

<body>

  <h1 id="me">大宝章 is Double Zhang</h1>

  <script>

    document.getElementById("me").style.color = "blue";

  </script>

</body>

实验结果字体为蓝色,终于渲染成功,从上而下万年不变的真理啊。

------------------------------------------------------------------------------------------------------------

实验四:

<script>
  window.onload = function(){
    document.getElementById("me").style.color = "blue";
  }
</script>
<body>
  <h1 id="me">大宝章 is Double Zhang</h1>
</body>

相比实验一添加了神器window.onload,字体为蓝色。这里有必要解释一下window.onload了,它表示网页完成了加载,包括DOM树的创建、网页中图片等外部资源的加载。window.onload=function(){这里的代码将在网页加载完成以后执行},这就是为什么实验四能够成功渲染蓝色字体,因为body里的内容已经加载完成,h1已经存在,才执行了颜色设置。

这里有一个隐患,当页面中需要加载的文件非常多(如图片),window.onload里面的代码就迟迟无法执行,将带来很差的用户体验。

------------------------------------------------------------------------------------------------------------

实验五:

<script>
  setTimeout(function(){

    document.getElementById("me").style.color = "blue";

  },3000); 

</script>
<body>
  <h1 id="me">大宝章 is Double Zhang</h1>
</body>

字体成功渲染为蓝色,因为做了一个定时器的延时3秒,在这3秒里,页面完成了加载工作,h1已经建立好,再添加颜色就没问题了,但是运行会看到字体会闪一下,闪之前为黑色,闪之后变为红色,因为页面刚加载好,h1默认呈现黑色,三秒时变为红色。

这也是一种方法,但是我们并不提倡,因为我们无法把握页面加载完成的准确时间,就意味着我们不能避免“闪一下”的问题,并且,setTimeout设置的延迟时间如果小于页面加载的时间,字体也不会渲染为蓝色。

-----------------------------------------------------------------------------------------------

实验六:

<script>

$(document).ready(function(){

  document.getElementById("me").style.color = "blue";

});   

</script>
<body>
  <h1 id="me">大宝章 is Double Zhang</h1>
</body>

字体成功渲染蓝色!wuli jQuery的ready方法,就是在DOM树创建完成后(HTML解析的第一步)就触发,无需等待页面中其他资源(图片等)的加载,成功解决了实验四中的隐患。

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

自己模拟一个jQuery的ready方法:

function myReady(fn){

  //利用能力检测区分浏览器

  if(document.addEventListener){

    document.addEventListener("DOMContentLoaded",fn,false);

  }

  else{  //这里是IE低版本浏览器

    IEContentLoaded(fn);

  }

  //IE模拟DOMContentLoaded

  function IEContentLoaded(fn){

    var d = document.window;

    //保证fn回调函数只执行一次

    var done = false;

    var init = function(){

      if(!done){

        done = true;

        fn();

      }

    }

    (function(){

      try{

        //DOM树未创建前调用doScroll会抛出异常

        d.documentElement.doScroll('left');

      }

      catch(e){

        //arguments.callee指向这个即可执行的(function(){})();

        //没有捕获异常意味着DOM成功创建,就可以执行回调函数了

        setTimeout(arguments.callee,60);  

        return;

      }

    })();

    //监听document的加载状态

    d.onreadystatechange = function(){

      if(d.readyState == 'complete'){

        d.onreadyState == null;

        init();

      }

    }

  }

}

window.onload与$(document).ready()的区别的更多相关文章

  1. window.onload和$(document).ready()的区别

    window.onload和$(document).ready()的区别,如下表所示   window.onload $(document).ready() 执行时间 在页面所有内容(图片.文件)加载 ...

  2. window.onload和document.ready的区别

    window.onload和document.ready虽然两个方法的运行效果都一样,但他们之间是存在着区别的: 一.从执行的时间 window.onload在dom文档结构加载完毕以后就可以执行,不 ...

  3. window.onload 与 $(document).ready() 的区别

    以浏览器装载文档为例,在页面加载完毕后,浏览器会通过 JavaScript 为 DOM 元素添加事件.在常规的 JavaScript 代码中,通常使用 window.onload 方法 ,而在 jQu ...

  4. 浏览器加载模式:window.onload和$(document).ready()的区别(详解)

    jQuery库文件是在body元素之前加载的,必须等待所有的DOM元素加载后,延迟支持DOM操作,否则就无法获取到. 在延迟等待加载,JavaScript提供了一个事件为load,方法如下: wind ...

  5. 【jQuery】window.onload 和 $(document).ready() 的区别

    ... 在Stack Overflow上看到了这个问题,自己翻译了过来. The onload event is a standard event in the DOM, while the read ...

  6. window.onload与document.ready的区别

    1. window.onload必须等到网页中所有的内容加载完(包含图片)才执行 document.ready网页中所有DOM结构绘制完执行,可能DOM并没有加载完 所有document.ready比 ...

  7. window.onload与$(document).ready()之区别

    1.执行时间 window.onload必须等到页面内包括图片的所有元素加载完毕后才能执行.         $(document).ready()是DOM结构绘制完毕后就执行,不必等到加载完毕. 2 ...

  8. window.onload()和$(document).ready的区别( $(document).ready == $(function(){ }) )

    首先$(function(){}) 和 $(document).ready(function(){}) 是一个方法,$(function(){})为简写(用的多) $(document).ready和 ...

  9. window.onload和$(document).ready(function(){})的区别

    前段时间在面试之前查找并整理了一下window.onload和$(document).ready(function(){})区别,今天有时间更到我的博客上,由于本人资历尚浅,如有不对的地方,还请指正. ...

随机推荐

  1. Android版本与api Level

    Platform Version API Level VERSION_CODE Notes Android 4.4 19 KITKAT Platform Highlights Android 4.3 ...

  2. 51nod1102(数塔)

    题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1002 题意:中文题诶- 思路:简单dp 从底层往上递推,每个 ...

  3. sqlserver Between And的问题

    Id Name RegisterDate 1 澎澎 2007/1/5 00:00:00 2 丁丁 2007/1/6 04:37:00 3 亞亞 2007/1/7 00:00:00 数据库的数据如上.若 ...

  4. linux学习日记之目录配制

    linux目录管理遵循FHS标准,主要目标是希望让使用者可以了解已安装软件通常放置于哪个目录上,所以他们希望独立的软件开发商.操作系统制作者.以及想要维护系统的用户,都遵循FHS的标准.也就是说FHS ...

  5. RSA算法学习

    package com.test.rsa; /* * 为了选择公钥和私钥,Bob必须执行如下步骤: * 1)选择两个大素数p和q.那么p和q应该多大呢?该值越大,RSA越难于破解,但是执行加密和解密所 ...

  6. CMD安装/删除服务

    服务安装 sc create "ddd" binpath= "D:\winservice\XXX\XXX.exe" 服务删除 sc delete "d ...

  7. 安装Kafka

    1.默认安装好zookeeper和scala2.下载安装包,解压 tar -zxvf kafka_2.11-0.9.0.1.tgz kafka_2.11-0.9.0.13.配置环境变量 vim /et ...

  8. 集成一体化的移动POS开单扫描解决方案--"移动开单掌上POS"。它集后台管理软件

    针对商贸企业的批发.零售管理设计的软硬件集成一体化的移动POS开单扫描解决方案--"移动开单掌上POS".它集后台管理软件.商品价格.库存等信息查询,店铺.展销会开单,移动捡货配送 ...

  9. JackRabbit的前世今生

    题记 写这系列有点老调重弹的味道,比如ahuaxuan已经在他的博客里对于JackRabbit 1.0做了很详细的阐述.之所以再写,是因为JCR推出了JCR 2.0,个人觉得有必要将一些新的特性再罗列 ...

  10. TFS 分支导致nuget项目依赖丢失

    问题: 项目的代码 在tfs上分支后,签出项目.编译时发现无法编译,原有的nuget来的包的dll都丢失了(项目签入时,默认会忽略dll) 在网上找了下,发现一个简单的解决方法: 在"程序包 ...