`
qingfengjushi1
  • 浏览: 141338 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

jquery源码分析之jQuery对象初始化

 
阅读更多
在jquery实际应用中可通过$或jQuery生成jquery对象,如$("#hr_three")可生成jquery对象,jquery是如何做到的呢?

jquery加载时,入口为如下匿名方法,
(function( global, factory ) {...} ([color=red]typeof window !== "undefined" ? window : this, function( window, noGlobal) {...}[/color]));


红色部分为调用参数,global为window对象,factory为匿名方法,factory指向的匿名方法包含了整个jquery的主要功能代码。

在jquery加载调用默认方法时,通过factory( global );对factory指向的匿名方法进行调用,可以看到匿名方法调用时第二个参数并未传入,因此noGlobal参数为undefined,以下代码初始化了window全局对象的jQuery及$属性。
if ( !noGlobal ) {
    // noGlobal为undefined,因此if判断为真
	window.jQuery = window.$ = jQuery;
}

将jQuery对象赋值给了全局的jQuery及$属性,因此,可以在jquery环境中使用jQuery或$来生成jquery对象。

再来看下jQuery对象的初始过程,
jQuery = function( selector, context ) {
    return new jQuery.fn.init( selector, context );
}

init = jQuery.fn.init = function( selector, context, root ) {
   ...
   // this实际上指向的是jQuery对象,根据selector的类别,对jQuery对象做了很多属性增强封装并最终返回
   return this;
}

为什么this会指向jQuery对象呢? 看以下代码
init.prototype = jQuery.fn;

jQuery.fn为jQuery的别名(参照下面代码),而init的prototype对象又指向jQuery.fn,因此init也是jQuery对象的别名,this就指向jQuery对象了。
jQuery.fn = jQuery.prototype = {
	jquery: version,
	constructor: jQuery,
    ...
}

以上代码jQuery.fn赋值为jQuery.prototype对象,并将其自身的构造方法指向 jQuery,因此jQuery.fn实际上就是jQuery对象的别名。为什么要为jQuery设置别名呢?个人感觉是想将jQuery对象方法用别名区分开来。

以上即为jQuery对象的初始框架。

如下代码段模拟了jQuery对象生成的骨架代码:
var test = function() {
			return new test.fn.init();
		};
		
		test.fn = test.prototype = {
			constructor: test,
			
			add: function() {
			}
		};

		var init = test.fn.init = function() {
		    // 增加长度属性
			this.length = 1;
			// 增加0属性
			this[ 0 ] = "test";
			// 返回自身
			return this;
		}
		
		init.prototype = test.fn;
		
		var test = test();
		console.log(test.length + "---" + test[0]);




分享到:
评论

相关推荐

    jQuery源码分析-03构造jQuery对象

    ### jQuery源码分析—构造jQuery对象 #### 一、源码结构概览 根据所提供的文件内容,本节将深入分析如何构建jQuery对象及其核心构造逻辑。首先,让我们从整体上理解jQuery构造函数的设计思路。 ##### 总体结构 ...

    jquery 源码分析

    ### jQuery源码分析 #### 一、概述 jQuery作为一个卓越的JavaScript库,以其简洁高效的特性在前端开发领域占据了一席之地。与Prototype、YUI、Mootools等其他JavaScript库相比,jQuery更加注重实用性,去除了一些...

    jQuery源码分析之init的详细介绍

    通过分析这个函数的源码,我们可以理解 jQuery 是如何处理不同的参数,从而初始化一个 jQuery 对象的。 初始化函数 init 接受三个参数:selector(选择器),context(上下文环境)和 root(根元素)。具体来讲,...

    jQuery源码分析之Callbacks详解

    这一点在某些场景下非常有用,比如只需要初始化一次的事件处理。 auto模型是一种能够自动触发加入Callbacks中函数的特性。当一个新的函数添加到Callbacks之后,它会自动执行之前已经添加的函数,并将最新的参数传递...

    JQuery源码的奥秘逐行分析视频教程

    ### JQuery源码的奥秘逐行分析视频教程 #### JQuery简介 JQuery 是一款轻量级的 JavaScript 库,它极大地简化了 HTML 文档遍历、事件处理、动画以及 Ajax 交互等操作。JQuery 提供了一个简洁且强大的 API 接口,...

    jquery1.43源码分析(核心部分)[收集].pdf

    《jQuery 1.4.3 源码分析——核心部分》 jQuery 是一个广泛使用的JavaScript库,它极大地简化了JavaScript的DOM操作、事件处理、动画制作和Ajax交互。在jQuery 1.4.3版本中,其核心部分主要包括选择器引擎、DOM操作...

    jquery源码 带格式

    - `jQuery`: 这个函数是jQuery的核心构造函数,当调用时,会创建一个新的`jQuery.fn.init`实例,这是初始化jQuery对象的主要方式。 #### JSON处理 - `rvalidchars`: 用于验证JSON字符串是否符合JSON格式规范的正则...

    jQuery源码分析系列_1.6

    ### jQuery源码分析系列_1.6 #### 一、前言 在现代Web开发领域,jQuery无疑是一款具有里程碑意义的JavaScript库。它通过简洁、强大的API极大地简化了DOM操作、事件处理、Ajax交互以及动画等功能,使得前端开发变得...

    jquery源码详解

    3. **方法初始化**:为新创建的 jQuery 对象添加一系列方法,如 `addClass()`, `remove()`, `html()`, `css()` 等。这些方法使开发者能够方便地操纵 DOM 节点。 ##### 2.2 jQuery 对象的特性 - **链式调用**:...

    jquery源码好不容易找到的与大家分享

    2. **函数封装**:jQuery将所有功能封装在`jQuery.fn`(即`jQuery.prototype`)对象中,通过`init`构造函数初始化实例,实现了面向对象的特性。 3. **$.extend()与$.fn.extend()**:这两个函数用于扩展jQuery对象和...

    jQuery 2.0.3 源码分析之core(一)整体架构

    首先,jQuery在内部使用了一个名为jQuery.fn.init的构造函数来实现对象的初始化。这个构造函数通过接受不同的参数来完成不同环境下的对象创建,比如在文档加载完成后执行的代码,就可以通过$().ready()的形式来进行...

    139.jQuery源码分析-魔术方法.rar

    《jQuery源码分析——魔术方法》 jQuery,作为一款广泛使用的JavaScript库,以其简洁的API和强大的功能赢得了开发者们的喜爱。在深入理解jQuery的工作原理时,我们常常会遇到一些“魔术方法”,这些方法在特定场景...

    jquery1.43源码分析(核心部分)

    ### jQuery 1.4.3 源码分析(核心部分) #### 一、引言 随着 Web 技术的不断发展,JavaScript 成为了前端开发中不可或缺的一部分。而在众多 JavaScript 库中,jQuery 几乎成为了网页开发的标准工具之一。本文将...

    Jquery 源码解读

    jQuery 在加载完成后会自动调用 `init` 方法来进行初始化: ```javascript jQuery.init(); ``` 这个方法负责处理一些基本的设置,比如设置默认的行为、绑定事件等。 ##### 3.7 重要方法:`ready` `ready` 方法是...

    通过jQuery源码学习javascript(二)

    在jQuery的实现中,`jQuery()`实际上是一个工厂方法,它返回的是一个经过初始化的对象,而不是直接返回`this`引用。在JavaScript中,`this`的值取决于函数调用的方式。在`jQuery`函数内部,`this`并不总是指向我们...

    jQuery 1.9.1源码分析系列(十)事件系统之主动触发事件和模拟冒泡处理

    1. **初始化事件**:如果传入的`event`是一个事件类型字符串,jQuery会创建一个新的`jQuery.Event`对象。同时,处理事件源的修正和构造事件处理参数。 2. **组合事件处理参数**:事件处理函数的参数可能包括`event`...

    JQUERY UI 开发指南源码

    JavaScript部分主要涉及到jQuery和jQuery UI的API调用,包括初始化组件、设置选项、响应事件等。通过分析这些代码,你可以深入理解jQuery UI的工作原理,并学会如何在自己的项目中应用。 此外,jQuery UI还支持主题...

Global site tag (gtag.js) - Google Analytics