博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
读jQuery源码有感
阅读量:6982 次
发布时间:2019-06-27

本文共 1489 字,大约阅读时间需要 4 分钟。

读之前的预备工作:

1.基础的js知识,以及html和css知识,和正则表达式知识。可以参考妙味课堂的基础js,html和css大纲。

2.JavaScript核心指南的知识

3.JavaScript设计模式的知识

4.使用过jQuery

 

 

有了预备工作,阅读源码你会比较顺利。

我阅读的是2.0.3无法压缩版本,源代码有注释。

代码先从整体开始阅读,

1.搞清楚的就是它的封装方式和继承方式,

var $ =jQuery = function(){    return new jQuery.fn.init();}jQuery.fn = jQuery.prototype = {    init : function(){        this.length = 0;        this.test = function(){            return this.length;        }        return this;    },    jquery: "2.0.3",    length: 1,    size: function() {        return this.length;    }}jQuery.fn.init.prototype = jQuery.fn;     //使用jQuery的原型对象覆盖init的原型对象alert( $().jquery );     //返回"2.0.3"alert( $().test() );     //返回0alert( $().size() );     //返回0

jQuery有其自身的静态方法和动态添加方法。所谓静态方法,就是jQuery各个模块都会调用到的公共方法。所谓动态添加方法,就是通过jQuery自己实现的extend函数来扩展的方法,这些方法一般jQuery内部不会使用到。

2.列出它的各个模块

Sizzle选择器,DOM操作,事件操作,样式操作,ajax操作,元素运动操作,回调函数队列操作(一次性调用多个函数,或设定某个函数只能调用一次),延迟函数操作(原先ajax回调函数形式是树状,现在是线状$.ajax("test.html").done(function(){ alert("哈哈,成功了!"); }).fail(function(){ alert("出错啦!"); });),数据缓存操作

3.一行一行阅读源代码

实际阅读过程中,你会遇到的困难大都是,

  1. 这个正则表达式什么意思
  2. 这么多if else嵌套究竟想表达什么个意思,而且为什么这么写
  3. js语言特有的语法所表达的意思,比如双感叹号!!在js里的作用,对null与undefined用!操作符时都会产生true的结果,所以用两个感叹号的作用就在于,如果明确设置了(非null/undefined/0""/等值),自然一样的值;如果没有设置,test就会默认为false,而不是null或undefined或0。还有>>>和~这些操作符,在js里都是特殊用法。

针对这些困难,你能做的就是

  1. 看注释
  2. 自己写个小Demo,设源码断点,一步步调试来观察代码流程。(对于源码里的各种情况判断,这里要考验你的Demo完整性,间接考研你的思维缜密性)
  3. 看第三方人怎么解读源代码,比如

 

 

最后,发现,读这个源代码,不需要你知道什么算法知识,甚至数据结构也可以不知道,设计模式其实也可以不去知道。

耐下心来,静下心来,有着一般的逻辑,就能看懂jQuery源码。

平凡的逻辑,也能读懂不平凡的jQuery库。 

 

 

转载地址:http://btvpl.baihongyu.com/

你可能感兴趣的文章
Windows与Linux系统拷贝文件之pscp的使用
查看>>
_xmlXPathNewContext", referenced from
查看>>
Netty3之ServerBootstrap分析
查看>>
小木木的Python学习笔记
查看>>
用SQL语句添加删除修改字段
查看>>
运维少年系列 python and cisco (1)
查看>>
c#时间转换
查看>>
调度器Quartz的简述与使用总结
查看>>
smokeping 安装
查看>>
Linux下安装oracle数据库步骤
查看>>
yum 不小心删除后安装
查看>>
vim 使用
查看>>
为敏感信息设置安全屏障
查看>>
mysql fabric安装使用测试
查看>>
java 对 mongoDB 分组统计操作 以及一些常用操作
查看>>
当你扛不住的时候就读读
查看>>
解决安装rrdtool遇到的一个问题
查看>>
linux启动过程
查看>>
我的友情链接
查看>>
我的友情链接
查看>>