从零开始写jQuery框架

作者:martin0728 来源:经典论坛 时间:2008-12-24 13:37:00 

摘要: 本文由简到繁地介绍了以jQuery作为蓝本的js框架开发步聚, 希望借助本文大家对jQuery这样的框架内部有一个大致的认识。

推荐:jQuery API 中英文帮助手册

随着时代发展,javascript阵营里面出现了越来越多的优秀的框架,大大简化了我们的开发工作,在我们使用这些框架的时候是不是也应该饮水思源想想它们都是怎样构建起来的呢?如果你不满足于仅仅是使用一些现成的API,而是深入了解它们内部的实现机制(照某人的说法, API是贬值最快的东西),最好的办法就是阅读它们的源代码了,前提是你读得懂。

最近两天研究了一下jQuery的源码,在这里将本人一些粗浅认识分享出来,不当之处请各位指正。好了,下面我们就来看看jQuery大概是怎样工作的,我假定你已经具备了一些基本的javascript知识,如果基础不够俺推荐你阅读《JavaScript高级程序设计》和《悟透JavaScript》这两本书。本文不适合对js里面的类、对象、函数、prototype等概念没有了解的朋友。

我们从最开始的说起:

首先构造一个对象给使用者,假定我们这个框架叫 Shaka   ( 俺的名字;) )

var Shaka = function(){};

 这里我们创建了一个空函数,里面什么也没有,这个函数实际上就是我们的构造函数。为了让我们生成的对象能够调用在prototype里定义出来的方法, 我们需要用原型的方式(把Shaka当作是一个类)给Shaka添加一些方法,于是定义::

Shaka.fn =  Shaka.prototype = {}; 

这里的Shaka.fn相当于Shaka.prototype的别名,方便以后使用,它们指向同一个引用。

OK,我们添加一个sayHello的方法, 给Shaka添加一个参数,这样这个框架最基本的样子已经有了,如果它有生命的话那么它现在是1岁, 看代码:

好啦,先别激动, 我们注意到这个框架跟jQuery在使用上是有一些差别的, 比如在jq 中我们可以这样写


jQuery('#myid').someMethod();  

这是怎样做到的呢, 也就是说 jQuery()这个构造函数返回了一个jQuery的对象实例,因此我们可以在上面调用它的方法,所以Shaka的构造函数应该返回一个实例,它看起来应该是这个样子:


var Shaka = function(){ return //返回Shaka的实例; };  

那么我们要如何取得一个Shaka的实例呢, 我们先来回顾一下使用prototype方式来模拟类的时候


var someObj = new  MyClass();  

这个时候实际上是创建一个新对象someObje,把新对象作为this指针,调用 MyClass函数,即类的构造函数, 然后 someObj 就获得了在 MyClass.prototype里面定义的方法, 这些方法内的this指针指当前对象实例。

在jQuery中使用了一个工厂方法来创建一个实例,这个方法位于jQuery.prototype中, 现在我们重新来定义Shaka.prototype, 给它添加一个init方法用于返回一个Shaka的实例, 并且把Shaka的构造函数稍稍改变一下:


var Shaka = function(age) { return new Shaka.fn.init(age); }; 

Shaka.fn = Shaka.prototype = {  
       init: function(age) { this.age = age; return this; }, 
       sayHello: function() { alert('I am a little baby, my age is ' + this.age + ' years old.'); } 
}; 

Shaka.fn.init.prototype = Shaka.fn; 

这里new Shaka.fn.init(age)创建的对象具有init方法的prototype指向对象的方法 , 因此我们将init方法的prototype指向 Shaka的prototype, 这样创建出来的对象就具有了Shaka.prototype里面定义的方法。

OK,现在我们的小宝宝变成大一点的宝宝了,打个招呼先:

嗯,好象有点样子了,但是光这样还不行,来点实际的, 我们在新框架中实现jquery里val()方法的部分功能,这个方法不加参数调用时返回指定ID的input的值,加参数时为设定这个input的值,与jQery一样,我们约定使用id来查找对象时使用"#"符号。把要查找的目标ID作为构造函数的参数传进去,我们给Shaka.prototype添加一个val()方法, 给Shaka添加一个selector的属性用于存储我们要查找的目标。:

Shaka.fn = Shaka.prototype = {  
       init: function(selector) { this.selector = selector; return this; }, 
       val: function(newValue) { //方法实现代码 } 
}; 
var Shaka = function(selector) { return new Shaka.fn.init(selector); }; 

 

标签:jQuery,框架,javascript
0
投稿

猜你喜欢

  • layui 富文本图片上传接口与普通按钮 文件上传接口的例子

    2024-05-22 10:36:28
  • ASP.NET教程第二讲 ASP.NET学习

    2007-08-07 12:01:00
  • MySQL中易被我们忽略的细节

    2024-01-21 09:54:48
  • C#连接Oracle数据库字符串(引入DLL)的方式

    2024-01-25 16:10:07
  • 值得收藏的10道python 面试题

    2022-04-22 12:10:33
  • 一文带你了解MySQL基于规则的优化

    2024-01-16 19:47:47
  • SQL SERVER 2008数据库日志文件收缩的方法

    2024-01-27 09:29:38
  • python版飞机大战代码分享

    2023-11-13 22:29:03
  • 请问在mssql“SQL事件探查器”里表格的标题,如CPU,Read,Write,Duration,SPID.........的解释

    2024-01-20 23:48:30
  • 基于Python实现图像的傅里叶变换

    2023-12-14 09:10:34
  • python网络编程学习笔记(三):socket网络服务器

    2023-01-11 10:40:29
  • Mootools 1.2教程(14)——定时器和哈希简介

    2008-12-08 12:50:00
  • python安装cx_Oracle模块常见问题与解决方法

    2021-04-24 13:00:27
  • python 利用opencv实现图像网络传输

    2023-05-27 12:52:16
  • JavaScript自定义分页样式

    2023-07-02 05:29:46
  • MySQL无法启动1067错误的又一种解决方法(机房断电)

    2024-01-13 08:55:25
  • javascript中的Function.prototye.bind

    2024-04-22 22:35:59
  • PHP编程入门的基本语法知识点总结

    2023-06-14 11:16:36
  • Python3.6日志Logging模块简单用法示例

    2021-03-18 06:47:38
  • Mysql数据库之索引优化

    2024-01-23 19:27:40
  • asp之家 网络编程 m.aspxhome.com