jquery ready函数深入分析

 更新时间:2016年08月25日 16:00:54   作者:掸尘  
本文主要介绍jquery ready,这里整理了相关资料及相关示例代码帮助大家学习参考,有兴趣的小伙伴可以参考下

最近看一些关于jquery ready 有人说他缓慢,有人说他快,说法不一。 于是自己深入研究一下。首先看了一下jquery 文档 关于ready 的描述

While JavaScript provides the load event for executing code when a page is rendered, this event does not get triggered until all assets such as images have been completely received. In most cases, the script can be run as soon as the DOM hierarchy has been fully constructed. The handler passed to .ready() is guaranteed to be executed after the DOM is ready, so this is usually the best place to attach all other event handlers and run other jQuery code. When using scripts that rely on the value of CSS style properties, it's important to reference external stylesheets or embed style elements before referencing the scripts.

In cases where code relies on loaded assets (for example, if the dimensions of an image are required), the code should be placed in a handler for the load event instead.

翻译一下

虽然JavaScript提供了load事件,当页面渲染完成之后会执行这个函数,在所以元素加载完成之前,这个函数不会被调用,例如图像。但是在大多数情况下,只要DOM结构加载完,脚本就可以尽快运行。传递给.ready()的事件句柄在DOM准备好后立即执行,因此通常情况下,最好把绑定事件句柄和其他jQuery代码都到这里来。但是当脚本依赖于CSS样式属性时,一定要在脚本之前引入外部样式或内嵌样式的元素。  
 
如果代码依赖于需加载完的元素(例如,想获取一个图片的尺寸大小),应该用.load()事件代替,并把代码放到load事件句柄中。    

依照文档上面的说明,在页面内有大量文档结构,图片资源时候,ready 是快于 load 的。文档里面也清晰的分析了什么时候用ready 什么时候用load。

下面分析一下jquery ready 的运行流程

$(handler) or $(document).ready(handler) →  ready() → bindReady() → 执行readyList.add( fn ) fn

 大致看一下源码

 下面是jquery 的 对象的 ready 源码

 jQuery.fn = jQuery.prototype = {  
      constructor: jQuery,  
      init: function( selector, context, rootjQuery ) {  
        // HANDLE: $(function)  
        // Shortcut for document ready  
        // 如果函数,则认为是DOM ready句柄  
        if ( jQuery.isFunction( selector ) ) {  
          return rootjQuery.ready( selector );  
        }  
      },  
      
      ready: function( fn ) {  
        // Attach the listeners  
        jQuery.bindReady(); // 绑定DOM ready监听器,跨浏览器,兼容标准浏览器和IE浏览器  
      
        // Add the callback  
           readyList.add( fn );// 将ready句柄添加到ready异步句柄队列  
      
        return this;  
      }  
    };  

 调用jquery 的 bindReady ,  增加ready回调!

  下面看一下 bindReady 大致源码

bindReady: function() { // jQuery.bindReady  
        if ( readyList ) {  
          return;  
        }  
 
        readyList =jQuery.Callbacks( "once memory" )// 初始化ready异步事件句柄队列  
 
        // Catch cases where $(document).ready() is called after the  
        // browser event has already occurred.  
        // 如果DOM已经完毕,立即调用jQuery.ready  
        if ( document.readyState === "complete" ) {  
          // Handle it asynchronously to allow scripts the opportunity to delay ready  
          // 重要的是异步  
          return setTimeout( jQuery.ready, 1 );  
        }  
      //下面是一些防御性的编程 故此省略
    ......
}

   这个应该很清楚  document.readyState == 'complete' 就会 执行 jquery 的 ready ,我很困惑的是为什么是 setTiemout(jQuery.ready,1) ,请返回上面看ready 的代码, readyList.add( fn ), 如果不是异步的,执行回调的就会放到 readyList.add( fn )之前了,因为执行是在jQuery 的ready 里面 readyList.fireWith( document, [ jQuery ] );readylist 是jquery 的callbacks ,就是管理回调函数的!不清楚的可以看看文档。

注:你会发现有两个ready,这两个是不同的,一个放到 jquery.prototype 就是我们$(doucument).ready这个,另一个是jquery的对象方法判断是否已经ready了的方法

ps : jquery博大精深,文章有错误之处,还请各位指正!

 以上就是对 jquery ready的资料整理,后续继续整理相关资料,谢谢大家对本站的支持!

相关文章

  • 详解C++中shared_ptr的使用教程

    详解C++中shared_ptr的使用教程

    shared_ptr能够记录对象被引用的次数,主要被用来管理动态创建的对象的销毁,这里我们就来详解C++中shared_ptr的使用教程,需要的朋友可以参考下
    2016-05-05
  • C/C++中异常处理详解及其作用介绍

    C/C++中异常处理详解及其作用介绍

    这篇文章主要介绍了C/C++中异常处理详解及其作用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • C语言实现抢红包算法

    C语言实现抢红包算法

    这篇文章主要为大家详细介绍了C语言抢红包算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • C++ const限定符以及顶层const和底层const的案例详解

    C++ const限定符以及顶层const和底层const的案例详解

    这篇文章主要介绍了C++ const限定符以及顶层const和底层const的案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • c++中八大排序算法

    c++中八大排序算法

    本篇文章主要介绍了八大排序算法,详细的介绍了八个算法思想,实现代码,稳定性,时间复杂度等,具有一定的参考价值,有需要的可以了解一下。
    2016-11-11
  • 详解C/C++高精度(加减乘除)算法中的压位优化

    详解C/C++高精度(加减乘除)算法中的压位优化

    在高精度计算中数组的每个元素存储一位10进制的数字,这样的存储方式并不是最优的,32位的整型其实至少可以存储9位高精度数字,数组元素存储更多的位数就是压位优化。本文将展示压位优化的原理以及压9位的实现和性能对比,需要的可以参考一下
    2023-01-01
  • C语言求字符串长度的四种方法实例代码

    C语言求字符串长度的四种方法实例代码

    在C语言的应用过程中经常性的会用到字符串,以及对字符串的长度进行计算的问题,下面这篇文章主要给大家介绍了关于C语言求字符串长度的四种方法的相关资料,需要的朋友可以参考下
    2022-12-12
  • 详解C++实现线程安全的单例模式

    详解C++实现线程安全的单例模式

    这篇文章主要介绍了C++实现线程安全的单例模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • OpenCV使用GrabCut实现抠图功能

    OpenCV使用GrabCut实现抠图功能

    Grabcut是基于图割(graph cut)实现的图像分割算法,它需要用户输入一个bounding box作为分割目标位置,实现对目标与背景的分离/分割。本文将使用GrabCut实现抠图功能,需要的可以参考一下
    2023-02-02
  • C语言基础之malloc和free函数详解

    C语言基础之malloc和free函数详解

    这篇文章主要介绍了C语言基础之malloc和free函数详解的相关资料,需要的朋友可以参考下
    2017-04-04

最新评论