从零开始写jQuery框架(2)

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

接着来

到目前为止我们已经创建一个可以工作的框架雏形,为了使程序可以更方便地被调用,比如jQuery可以使用$符号来简写,我们也弄一个,在此之前我们先来回顾两个东西:

1. 我们在脚本中可以这样定义变量:

var foo = 'someThing';  
bar = 'otherthing'; 

这样两种写法都是合法的,但是意义完全不同, 第一个语句创建了一个新的变量,而第二个是定义了window对象的一个属性,相当于window.bar = 'otherthing';, 因此我们想使我们的Shaka具有这样的调用方式能力: $.someMethod();就需要将Shaka设置为window的一个属性, 于是我们的Shaka构造函数就得写成这样:

var Shaka = window.Shaka = window.$ = function(selector) { return new Shaka.fn.init(selector); }; 

2. javascript的匿名函数.

创建并执行一个匿名函数的基本形式: (function(){ alert('Hello World!'); })(); 为什么要用到匿名函数呢,因为我们不想把Shaka的内部实现暴露出来,这样容易与其它代码冲突,只提供一个单一的入口,我们可以这样测试一下:

然后,还有一个问题需要解决,俺们的框架做出来了但是还很简陋,在这之前我们需要让它与其它的框架协同工作,因此带来一个问题, 如果我们都使用$作为简写形式就会冲突了, 象jQuery一样,我们需要提供一个noConfilit的方法“出让”$的使用权。在我们的程序最开始处加入下面的代码:

var _$ = window.$;

意思是将此前定义的$对象引用放到 _$ 中, 然后我们再给Shaka扩展一个方法出来, 如果其它开发者需要自行扩展的话也可以使用这个方式(jQuery的extend方法提供了更为强大的功能,请大家自行研究):

(function($){ //extend method definition. })(Shaka);

意思是将Shaka作为这个匿名函数的参数来调用这个方法。

前面我们讲过 Shaka.fn 就是 Shaka.prototype 的别名,因此我们要在Shaka.prototype 里面添加新的方法就可以写成这样

(function($){ 
       $.fn.noConflict = function(){ 
              window.$ = _$;//把$还给在开始处取得的引用.
       };
})(Shaka);

现在我们来看一个完整的:

现在好象不错了,我们的Shaka baby已经5岁了;) , 当然这还只是个简陋的东西,要实现健壮而强大的功能还需要付出很多努力, 希望诸位爹妈把自己的孩子培养成人才, good luck!

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

猜你喜欢

  • mysql 5.7.21 winx64安装配置方法图文教程

    2024-01-28 10:32:00
  • 解读SQL一些语句执行后出现异常不会回滚的问题

    2024-01-22 12:52:59
  • 使用sublime text3搭建Python编辑环境的实现

    2023-01-20 21:01:56
  • css3弹性盒模型

    2010-05-10 20:47:00
  • Python中if __name__ == "__main__"详细解释

    2023-10-16 06:36:56
  • 使用css2.1实现多重背景、多重边框效果[译]

    2010-08-23 16:32:00
  • python获得一个月有多少天的方法

    2022-02-21 00:55:15
  • DataReader深入解析:持续更新

    2023-07-11 06:24:08
  • SQL Server 2000日志转移实现高可用性

    2009-01-20 15:04:00
  • python 生成器协程运算实例

    2021-11-22 05:27:51
  • PHP crypt()函数的用法讲解

    2023-06-13 03:08:05
  • 比较详细的MySQL字段类型说明

    2024-01-20 16:13:02
  • Python列表创建与销毁及缓存池机制

    2023-11-29 14:21:21
  • mysql 列转行,合并字段的方法(必看)

    2024-01-28 03:09:04
  • 基于事件冒泡、事件捕获和事件委托详解

    2024-04-28 09:43:33
  • 四大因素扼杀了中国人的创造力

    2008-09-11 18:05:00
  • js实现登录验证码

    2023-09-06 05:43:27
  • Python中使用语句导入模块或包的机制研究

    2023-02-21 15:06:40
  • CSS样式设计技巧十则

    2008-06-04 12:18:00
  • 使用Python获取爱奇艺电视剧弹幕数据的示例代码

    2022-08-09 08:38:29
  • asp之家 网络编程 m.aspxhome.com