jQuery之ready实现

ready用来实现延迟加载的方法,最主要的功能就是$(document).ready(function(){......}),当整个document加载完成后再执行其中的方法。让我们看一下jQuery里具体的实现方式。

首先看一下源码:

1. .ready()方法

2. jQuery.bindReady()方法

 

3. Deferred方法——个人认为可以当做一个js闭包的很好的例子

 

 


 

4.jQuery.ready()

 

 

当执行.ready()方法时,则会触发jQuery.bindReady(),然后创建readyList = jQuery._Deferred();返回的deferred对象是一个闭包,它封装了一些方法,主要是done,resolveWith,  done用来push function to callbacklist   resolveWith则是执行callbacklist里的function.在bindReady中还有个重要功能就是绑定原生事件,当dom加载完成以后,触发jQuery.ready()方法。该方法做一些已经ready过的标记,并且触发readyList.resolveWith。


值得学习的地方

1.不同浏览器内核绑定onload方法

2.deferred闭包的使用

3.队列处理的技巧

 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值