jQuery $(document).ready()和JavaScript onload事件详解区别

jQuery $(document).ready()和window.onload

  根据ready()方法的API说明http://api.jquery.com/ready/

  这个方法接收一个function类型的参数ready(handler), 方法的作用是: Specify a function to execute when the DOM is fully loaded.

  即当DOM加载完毕的时候,执行这个指定的方法.

  因为只有document的状态ready之后,对page的操作才是安全的.

  $(document).ready()仅在DOM准备好的时候执行一次.

 

  与之相比,load事件会等到页面渲染完成执行,即等到所有的资源(比如图片)都完全加载完成的时候.

  $(window).load(function(){…})会等整个页面,不仅仅是DOM,还包括图像和iframes都准备好之后,再执行.

  而ready()是在DOM准备好之后就执行了,即DOM树建立完成的时候.所以通常ready()是一个更好的时机.

 

  如果DOM初始化完成之后再调用ready()方法,传入的新的handler将会立即执行.

 

  注意:ready()方法多次调用,传入的handler方法会串联执行(追加).

  而JavaScript中,window.onload是赋值一个方法,即后面的会覆盖掉前面的.


一系列测试结论 ,详细看链接

结论:触发先后次序

在Chrome中:

  ready()

  window.οnlοad==document.body.onload

  <body οnlοad=“">

 

在FireFox中:

  ready()

  window.οnlοad==<body οnlοad=“”>==document.body.onload

 

  此分析的结果跟浏览器,甚至浏览器版本相关,本文写于2015.2.6

  Chrome Version: 40.0.2214.94

  FireFox Version: 35.0

转发:http://www.cnblogs.com/mengdd/p/4276801.html

转载于:https://my.oschina.net/u/1579617/blog/515910

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值