jquery ready函数深入分析

所属分类: 软件编程 / C 语言 阅读数: 70
收藏 0 赞 0 分享

最近看一些关于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++实现string与各种类型之间的转换

这个类在头文件中定义, < sstream>库定义了三种类:istringstream、ostringstream和stringstream,分别用来进行流的输入、输出和输入输出操作。另外,每个类都有一个对应的宽字符集版本
收藏 0 赞 0 分享

C++如何通过ostringstream实现任意类型转string

再使用整型转string的时候感觉有点棘手,因为itoa不是标准C里面的,而且即便是有itoa,其他类型转string不是很方便。后来去网上找了一下,发现有一个好方法
收藏 0 赞 0 分享

C/C++指针小结

要搞清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区
收藏 0 赞 0 分享

C++ 类的静态成员深入解析

在C++中类的静态成员变量和静态成员函数是个容易出错的地方,本文先通过几个例子来总结静态成员变量和成员函数使用规则,再给出一个实例来加深印象
收藏 0 赞 0 分享

C++类的静态成员初始化详细讲解

通常静态数据成员在类声明中声明,在包含类方法的文件中初始化.初始化时使用作用域操作符来指出静态成员所属的类.但如果静态成员是整型或是枚举型const,则可以在类声明中初始化
收藏 0 赞 0 分享

C++类静态成员与类静态成员函数详解

静态成员不可在类体内进行赋值,因为它是被所有该类的对象所共享的。你在一个对象里给它赋值,其他对象里的该成员也会发生变化。为了避免混乱,所以不可在类体内进行赋值
收藏 0 赞 0 分享

C++中的friend友元函数详细解析

友元可以是一个函数,该函数被称为友元函数;友元也可以是一个类,该类被称为友元类。友元函数的特点是能够访问类中的私有成员的非成员函数。友元函数从语法上看,它与普通函数一样,即在定义上和调用上与普通函数一样
收藏 0 赞 0 分享

static全局变量与普通的全局变量的区别详细解析

以下是对static全局变量与普通的全局变量的区别进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
收藏 0 赞 0 分享

C++ explicit关键字的应用方法详细讲解

C++ explicit关键字用来修饰类的构造函数,表明该构造函数是显式的,既然有"显式"那么必然就有"隐式",那么什么是显示而什么又是隐式的呢?下面就让我们一起来看看这方面的知识吧
收藏 0 赞 0 分享

教你5分钟轻松搞定内存字节对齐

随便google一下,人家就可以跟你解释的,一大堆的道理,我们没怎么多时间,讨论为何要对齐.直入主题,怎么判断内存对齐规则,sizeof的结果怎么来的,请牢记以下3条原则
收藏 0 赞 0 分享
查看更多