zepto源码分析·整体架构
代码数量
1.2.0版本代码量为1650行,去掉注释大概1500左右
代码模块
默认版本只包括核心模块,事件模块,ajax模块,form模块和ie模块,其它模块需要自行拓展加入,其中form模块只包含序列化操作和submit提交事件实现,ie模块只包括一点兼容性处理,两者码量极少,因此不做分析
执行结构
典型的即时函数,保证封装性
(function (global, factory) {
// amd,cmd的模块化检测
})(this, function(window) {
// zepto初始化代码
})
模块结构
(function (global, factory) {
// amd,cmd的模块化检测
})(this, function(window) {
// 核心模块
var Zepto = (function () {
}();
// 事件模块
;(function (){
})(Zepto)
// ajax模块
;(function (){
})(Zepto)
// form模块
;(function (){
})(Zepto)
// ie模块
;(function (){
})()
})
架构原理
(function (global, factory) {
// amd,cmd的模块化检测
})(this, function(window) {
// 核心模块
var Zepto = (function () {
var $, zepto = {};
// 第四步
function Z(dom, selector) {
// zepto对象创建,返回this
}
// 第三步
zepto.Z = function(dom, selector) {
return new Z(dom, selector)
}
// 是否为zepto.Z实例
zepto.isZ = function(object) {
return object instanceof zepto.Z
}
// 第二步
zepto.init = function(selector, context) {
// 选择器解析,获得dom元素集合
return zepto.Z(dom, selector);
}
// 第一步
$ = function (selector, context) {
return zepto.init(selector, context)
}
// 定义代表原型对象的fn属性
$.fn = {
constructor: zepto.Z,
length: 0
}
// 串通原型链
zepto.Z.prototype = Z.prototype = $.fn;
// 赋值zepto引用给$
$.zepto = zepto;
return $
}();
// window上注册Zepto
window.Zepto = Zepto
window.$ === undefined && (window.$ = Zepto)
// 其它模块省略...
})
1.库的架构方面,先是定义了2个变量,未声明的$和zepto对象;将$赋值为函数,定义fn属性来作为库本身的原型对象,对zepto对象定义一些操作方法
2.通过$方法实现选择器初始化操作,通过zepto.init实现dom集合生成,通过zepto.Z和Z函数生成一个Zepto对象,也就是如上注释的1,2,3,4步
3.其中Z.prototype = $.fn是为new Z实例定义原型,zepto.Z.prototype = Z.prototype则只是用于zepto.isZ函数操作,以便判断是否传入的内容为zepto.Z实例
4.个人感觉zepto.isZ函数实现略微麻烦,改成如下形式会更简洁
// 核心模块
var Zepto = (function () {
var $, zepto = {};
zepto.isZ = function(object) {
// zepto.Z改成Z
return object instanceof Z
}
// zepto.Z改成Z
$.fn = {
constructor: Z,
length: 0
}
// zepto.Z.prototype = Z.prototype去掉
Z.prototype = $.fn;
return $
}();
对比jquery架构
var jQuery = function( selector, context ) {
// 避免this instanceof jQuery判断
// 避免new jQuery的死循环
// 初始化方法采用原型上的init方法
return new jQuery.fn.init( selector, context );
}
// 定义fn属性指向jQuery原型
jQuery.fn = jQuery.prototype = {
constructor: jQuery
}
// 通过将init方法的原型指向jquery原型解决this问题
jQuery.fn.init.prototype = jQuery.fn;
// 通过this的力量共享extend拓展方法,实现根据调用对象进行对应拓展
jQuery.extend = jQuery.fn.extend = function() {
}
jQuery的原型链构建和extend实现真是精妙绝伦,jQuer的架构实现比Zepto更简洁,作用上更清晰,Zepto的实现相对繁琐
zepto源码分析·整体架构的更多相关文章
- 精尽 MyBatis 源码分析 - 整体架构
该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...
- Fresco 源码分析 —— 整体架构
Fresco 是我们项目中图片加载专用框架.虽然我不是负责 Fresco 框架,但是由本人负责组里的图片加载浏览等工作,因此了解 Fresco 的源码有助于我今后的工作,也可以学习 Fresco 的源 ...
- jquery-2.0.3 源码分析 整体架构
关键 var jQuery = function( selector, context ) { return new jQuery.fn.init(); } jQuery.fn = jQuery.pr ...
- [转]Libev源码分析 -- 整体设计
Libev源码分析 -- 整体设计 libev是Marc Lehmann用C写的高性能事件循环库.通过libev,可以灵活地把各种事件组织管理起来,如:时钟.io.信号等.libev在业界内也是广受好 ...
- zepto源码分析系列
如果你也开发移动端web,如果你也用zepto,应该值得你看看.有问题请留言. Zepto源码分析-架构 Zepto源码分析-zepto(DOM)模块 Zepto源码分析-callbacks模块 Ze ...
- 一个普通的 Zepto 源码分析(二) - ajax 模块
一个普通的 Zepto 源码分析(二) - ajax 模块 普通的路人,普通地瞧.分析时使用的是目前最新 1.2.0 版本. Zepto 可以由许多模块组成,默认包含的模块有 zepto 核心模块,以 ...
- 一个普通的 Zepto 源码分析(三) - event 模块
一个普通的 Zepto 源码分析(三) - event 模块 普通的路人,普通地瞧.分析时使用的是目前最新 1.2.0 版本. Zepto 可以由许多模块组成,默认包含的模块有 zepto 核心模块, ...
- 一个普通的 Zepto 源码分析(一) - ie 与 form 模块
一个普通的 Zepto 源码分析(一) - ie 与 form 模块 普通的路人,普通地瞧.分析时使用的是目前最新 1.2.0 版本. Zepto 可以由许多模块组成,默认包含的模块有 zepto 核 ...
- Zepto源码分析(一)核心代码分析
本文只分析核心的部分代码,并且在这部分代码有删减,但是不影响代码的正常运行. 目录 * 用闭包封装Zepto * 开始处理细节 * 正式处理数据(获取选择器选择的DOM) * 正式处理数据(添加DOM ...
随机推荐
- 从零开始使用 Webpack 搭建 Vue 开发环境
创建项目 先创建一个空目录,在该目录打开命令行,执行 npm init 命令创建一个项目(无法执行 npm 命令?需要先安装 Node),这个过程会提示输入一些内容,随意输入就行,完成后会自动生成一个 ...
- java数据结构——队列、循环队列(Queue)
每天进步一点点,坚持就是成功. 1.队列 /** * 人无完人,如有bug,还请斧正 * 继续学习Java数据结构————队列(列队) * 队列和栈一样,都是使用数组,但是队列多了一个队头,队头访问数 ...
- Python学习-迭代器、生成器
一.迭代器 1. 可迭代对象 我们知道字符串.列表.元组.字典.集合都可以使用for语句进行循环遍历,然后输出每一个元素,这些都是可迭代对象. 检查对象是否是可迭代对象可以用两种方式去判断: (1)使 ...
- 数据结构与算法(C/C++版)【排序】
第八章<排序> 一.直接插入排序 //直接插入排序 //算法思想:每趟将一个待排的关键字按照其值的大小插入到已经排好的部分有序序列的适当位置上,直到所有待排关键字都被插入到有序序列中为 ...
- mysql 5.7 Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column ...报错
使用mysql在执行一条插入语句时 , ', "hhh"); 报错:Expression #1 of ORDER BY clause is not in GROUP BY clau ...
- 阿里云服务器CentOS6.9安装SVN
1.安装SVN yum -y install subversion 出现Complete表明安装成功 2.创建SVN仓库目录 mkdir -p /data/svn/repositories/yyksv ...
- 【SQL server基础】手动创建数据库和表格
use master go if exists(select * from sysdatabases where name='learning') drop database learning go ...
- Stanford公开课《编译原理》学习笔记(2)递归下降法
目录 一. Parse阶段 CFG Recursive Descent(递归下降遍历) 二. 递归下降遍历 2.1 预备知识 2.2 多行语句的处理思路 2.3 简易的文法定义 2.4 文法产生式的代 ...
- 浅谈Java的内存模型以及交互
本文的内存模型只写虚拟机内存模型,物理机的不予描述. Java内存模型 在Java中,虚拟机将运行时区域分成6中,如下图: 程序计数器:用来记录当前线程执行到哪一步操作.在多 ...
- Kafka0.11之RoundRobinPartitioner/HashPartitioner(Scala):
RoundRobinPartitioner/HashPartitioner: import java.util import java.util.concurrent.atomic.AtomicLon ...