`

jQuery工作原理解析以及源代码示例(转)

 
阅读更多
jQuery的开篇声明里有一段非常重要的话:jQuery是为了改变javascript的编码方式而设计的.
从这段话可以看出jQuery本身并不是UI组件库或其他的一般AJAX类库.
jQuery改变javascript编码方式!
那么它是如何实现它的声明的呢?这里,用以下的一段简短的使用流程:
1)查找(创建)jQuery对象:$(”selector”);
2)调用jQuery对象的方法完成我们需要完成的工作:$(”selector”).doOurWork();
ok,jQuery就是以这种可以说是最简单的编码逻辑来改变javascript编码方式的.这两个步骤是jQuery的编码逻辑核心!

要实现这种简洁编码方式,创建jQuery对象这一环节至关重要.因此,jQuery的dom元素查找能力相当强悍.此外,jQuery对象的方法肯定是有限的,有限的方法满足不了日益增长各有所需的要求,所以,必须提供jQuery对象方法的扩展能力.
强悍的dom元素查找能力,以及随心所欲的方法扩展,这两点正是jQuery的核心所在!
来一个简单的示例,来说明jQuery是如何工作的:

< !DOCTYPE html PUBLIC ”-//W3C//DTD XHTML 1.0 Transitional//EN” ”http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml” >
<head>
    <title>无标题页</title>
</head>
<body id=”bd”>
<a href=”http://www.baidu.com”>baidu</a>
</body>
</html>
<script type=”text/javascript” src=”../Script/jquery.js”></script>
<script type=”text/javascript” >
$(function(){
    $(“a“).click(function(e){//1)查找$(”a”);2)jQuery对象事件click;3)jQuery对象方法hide
        $(this).hide(“slow“);
        return false;   
    });
});
</script>

jQuery中有一个\”配置”的思想,这一点使得对象的属性/事件等设置变得容易理解且十分简便,如下一个拖拽组件的初始化:

$(document).ready(
    function()
    {
        $(’#drag1′).Draggable({
            handle: “ax“,               //属性设置
            onStart: function(el,x,y){  //事件监听器设置      
            }
        });
    }
);

可以看到,$(”#drag1″)是查找并创建一个jquery对象,然后调用Draggable方法进行拖拽初始化,在此方法调用时,传递一个\”配置”对象,进行拖拽操作的初始化配置.
这一”配置”的思想,极大简化了一些编码步骤,并相当直观和易懂.

以下我进行三个问答:
1) 问:为什么$(selector)之后,返回的是jQuery对象?
答:从jQuery的源代码中,我们可以知道:var $ = jQuery.因此当我们$(selector)操作时,其实就是jQuery(selector),创建的是一个jQuery对象.当然正确的写法应该是这样的:var jq = new $(selector);而jQuery使用了一个小技巧在外部避免了new,在jquery方法内部:if ( window == this ) return new jQuery(selector);
2) 问:为什么创建一个jQuery对象之后,我们可以这样写$(selector).each(function(index){…});进行遍历操作呢?
答:其实jQuery(selector)方法调用时,在jQuery(selector)方法内部,最后返回的是一个数组:return this.setArray(a);而each方法体内部是一个for循环,在循环体内是这样调用的:method.call(this[i],i).
3) 问:为什么jQuery能做到jQuery对象属性/方法/事件的插件式扩展?
答:如果您有一些javasciprt的面向对象方面的知识,就会知道,jQuery.prototype原型对象上的扩展属性/方法和事件,将会给jQuery的对象\”扩展”.基于这一点,jQuery是这样写的:jQuery.fn = jQuery.prototype.所以,当我们扩展一个插件功能时,如下:
jQuery.fn.check = function() {
  return this.each(function() {
    this.checked = true;
  });
};

其实就是:
jQuery.prototype.check = function() {
  return this.each(function() {
    this.checked = true;
  });
};

综上所述,jQuery给我们带来了一个简洁方便的编码模型(1>创建jQuery对象;2>直接使用jQuery对象的属性/方法/事件),一个强悍的dom元素查找器($),插件式编程接口(jQuery.fn),以及插件初始化的”配置”对象思想.
附:实现自己的jQuery

< !DOCTYPE html PUBLIC ”-//W3C//DTD XHTML 1.0 Transitional//EN” ”http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>

<html xmlns=”http://www.w3.org/1999/xhtml”>
<head>
    <title>Untitled Page</title>
</head>
<body>
<div id=”d”>divvv</div>
<div id=”fsd”>fdsf</div>
</body>
</html>
<script type=”text/javascript”>
//实现自己的MyQuery框架
var MyQuery = function(selector){
    if ( window == this ) return new MyQuery(selector);
    //这里只实现dom类型的简单查找,嘿嘿
    var doms = document.getElementsByTagName(selector);
    var arr = [];
    for(var i=0; i<doms .length; i++){
        arr.push(doms.item(i));
    }
    return this.setArray(arr);
}
MyQuery.prototype.setArray = function( arr ) {
        this.length = 0;
        [].push.apply( this, arr );
        return this;
}
MyQuery.fn = MyQuery.prototype;
var $ = MyQuery;

//插件扩展1)each
MyQuery.fn.each = function(method){
    for(var i=0,l=this.length; i<l; i++){
        method.call(this[i],i);
    }
}
//插件扩展2)show
MyQuery.fn.show = function(){
    this.each(function(i){
        alert(i+“:“+this.id+“:“+this.innerHTML);
    });
}
//debugger
$(“div“).show();
</script></doms></script>

Tags: none
分享到:
评论

相关推荐

    jQuery网页开发实例精解源代码

    这本书的源代码包含了书中各个实例的完整实现,这使得读者能够直接运行和调试代码,加深对jQuery原理的理解。源代码的结构可能按照书中的章节进行组织,每个章节对应一个或多个实例,覆盖了DOM操作、事件处理、选择...

    jQuery攻略 源代码

    通过这些源代码,开发者可以深入理解jQuery的内部工作原理,学习如何有效地应用jQuery方法和函数。源代码通常包括一系列示例文件,它们展示了如何使用jQuery解决实际问题,例如选择元素、操作DOM、触发和处理事件、...

    jQuery 用户界面库实例源代码打包.rar

    此外,该压缩包还特别适合那些正在学习jQuery的朋友,通过实践和分析源代码,能够更深入地理解jQuery UI的工作原理和最佳实践。 标签“脚本资源-jQuery”明确了资源的类型,即与jQuery相关的脚本资源。这意味着我们...

    jquery UI 1.7源代码

    《jQuery UI 1.7源代码深度解析》 jQuery UI是基于jQuery库的交互式用户界面组件集合,它为Web开发者提供了丰富的可定制组件,包括日期选择器、对话框、拖放功能、滑块等。在本文中,我们将深入探讨jQuery UI 1.7的...

    jQuery Mobile源代码.zip

    jQuery Mobile 的源代码是其强大功能的基石,深入学习源码可以帮助我们更好地掌握其工作原理和设计模式。 在源代码中,我们可以看到jQuery Mobile是如何通过数据属性(data-attributes)和页面结构来增强HTML元素的...

    JQuery权威指南源代码

    源代码是理论知识的实践载体,通过阅读和研究这些代码,我们可以更直观地理解jQuery的工作原理,并提升我们的前端开发能力。 jQuery是一个高效、简洁且功能丰富的JavaScript库,它极大地简化了JavaScript的DOM操作...

    jQuery权威指南-配套源代码

    《jQuery权威指南》是一本深入解析jQuery库的书籍,它为...总的来说,这个压缩包提供了学习和实践jQuery的宝贵资源,通过阅读《jQuery权威指南》并配合源代码,读者可以深入理解jQuery的工作原理,并提升实际开发技能。

    jquery-easyui-1.3.4源代码 + DEMO + API

    《jQuery EasyUI 1.3.4:源代码解析与实战指南》 jQuery EasyUI 是一个基于 jQuery 的轻量级框架,它为开发者提供了一系列组件,使得构建交互式的Web应用变得更加简单。本篇将深入探讨 jQuery EasyUI 1.3.4 版本的...

    jQueryEasyUI 1.1完整源代码

    这个1.1版本包含了完整的源代码,允许开发者深入理解其工作原理,并进行定制和优化。 1. **jQueryEasyUI 主要特性** - **组件丰富**: 包括对话框(dialog)、表单(form)、数据网格(datagrid)、树形控件(tree...

    jquery权威指南配套源代码

    通过分析这些源代码,我们可以深入学习jQuery的核心功能以及在实际项目中的应用。 1. **jQuery基础**:jQuery的核心是简化DOM操作,事件处理和动画效果。源代码中可能包含了如何选择元素(如`$()`选择器)、操作CSS...

    精妙绝伦的jQuery 源代码

    在这里,我们将探讨jQuery的核心概念、设计模式以及源代码中的关键部分。 首先,jQuery是一个轻量级的JavaScript库,它简化了HTML文档遍历、事件处理、动画制作和Ajax交互等任务。jQuery的设计目标是使复杂的...

    jquery-Raty源代码

    **jQuery Raty源代码解析与应用** jQuery Raty是一款广泛应用于移动端的评星插件,它为用户提供了直观、易用的星级评价功能。这款插件以其灵活性和自定义性深受开发者喜爱,使得在网页中集成评分系统变得简单快捷。...

    jquery-easyui源代码

    《jQuery EasyUI 源代码解析》 jQuery EasyUI 是一个基于 jQuery 的前端框架,它为开发者提供了构建用户界面的便捷工具。这个框架的核心理念是简化网页开发,通过简单的 JavaScript API 实现丰富的交互效果和组件...

    JQuery权威指南书+书的源代码

    源代码部分包含与书中示例和练习配套的代码,这些代码通常以HTML、CSS和JavaScript文件的形式存在,读者可以下载并运行它们,以加深对jQuery实际应用的理解。通过实际操作,你可以学习到如何将理论知识转化为实际的...

    jQuery基础教程+锋利的jQuery+源代码+jquery1.7.2中文API+jquery-1.7.2.min.js.rar

    而"锋利的jQuery+源代码.rar"可能包含书中示例代码,这对于理解书中实例并进行实践至关重要。 学习jQuery,不仅能够提高开发效率,还能让你编写出更加流畅、用户体验更好的网页应用。无论是初学者还是有一定经验的...

    Ajax基础教程_示例源代码

    这些源代码是学习Ajax技术的理想起点,你可以通过它们深入理解Ajax的工作原理,并将其应用于自己的项目中。 1. **Ajax的基本概念**:Ajax并非一种单一的技术,而是一组用于创建动态、交互性更强网页的多种技术的...

    jquery html5网页播放器代码.zip

    本篇文章将详细解析“jquery html5网页播放器代码.zip”中的实现原理,并探讨如何根据项目需求进行自定义样式调整。 HTML5引入了`&lt;video&gt;`标签,使得在网页中内嵌视频成为可能,而jQuery作为一个强大的JavaScript库...

    DWR应用示例源代码,很好地说明了dwr工作原理

    在这个"DWR应用示例源代码"中,我们可以深入理解DWR的工作原理及其实际应用。 DWR的核心概念包括三个主要部分:`dwrc.js`(客户端库)、`DWR Engine`(服务器端组件)和`Servlet`(DWR引擎的入口点)。以下是对这些...

    Jquery 权威指南配套源码

    通过分析这些源码,读者不仅可以理解jQuery的基本用法,还能深入探究其工作原理,提升实际项目中的应用能力。同时,这些示例也可以作为实践项目的一部分,帮助读者巩固理论知识并增强动手能力。

Global site tag (gtag.js) - Google Analytics