代码数量

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源码分析·整体架构的更多相关文章

  1. 精尽 MyBatis 源码分析 - 整体架构

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

  2. Fresco 源码分析 —— 整体架构

    Fresco 是我们项目中图片加载专用框架.虽然我不是负责 Fresco 框架,但是由本人负责组里的图片加载浏览等工作,因此了解 Fresco 的源码有助于我今后的工作,也可以学习 Fresco 的源 ...

  3. jquery-2.0.3 源码分析 整体架构

    关键 var jQuery = function( selector, context ) { return new jQuery.fn.init(); } jQuery.fn = jQuery.pr ...

  4. [转]Libev源码分析 -- 整体设计

    Libev源码分析 -- 整体设计 libev是Marc Lehmann用C写的高性能事件循环库.通过libev,可以灵活地把各种事件组织管理起来,如:时钟.io.信号等.libev在业界内也是广受好 ...

  5. zepto源码分析系列

    如果你也开发移动端web,如果你也用zepto,应该值得你看看.有问题请留言. Zepto源码分析-架构 Zepto源码分析-zepto(DOM)模块 Zepto源码分析-callbacks模块 Ze ...

  6. 一个普通的 Zepto 源码分析(二) - ajax 模块

    一个普通的 Zepto 源码分析(二) - ajax 模块 普通的路人,普通地瞧.分析时使用的是目前最新 1.2.0 版本. Zepto 可以由许多模块组成,默认包含的模块有 zepto 核心模块,以 ...

  7. 一个普通的 Zepto 源码分析(三) - event 模块

    一个普通的 Zepto 源码分析(三) - event 模块 普通的路人,普通地瞧.分析时使用的是目前最新 1.2.0 版本. Zepto 可以由许多模块组成,默认包含的模块有 zepto 核心模块, ...

  8. 一个普通的 Zepto 源码分析(一) - ie 与 form 模块

    一个普通的 Zepto 源码分析(一) - ie 与 form 模块 普通的路人,普通地瞧.分析时使用的是目前最新 1.2.0 版本. Zepto 可以由许多模块组成,默认包含的模块有 zepto 核 ...

  9. Zepto源码分析(一)核心代码分析

    本文只分析核心的部分代码,并且在这部分代码有删减,但是不影响代码的正常运行. 目录 * 用闭包封装Zepto * 开始处理细节 * 正式处理数据(获取选择器选择的DOM) * 正式处理数据(添加DOM ...

随机推荐

  1. java架构之路-(mysql底层原理)Mysql事务隔离与MVCC

    上几篇博客我们大致讲了一下mysql的底层结构,什么B+tree,什么Hash需要回行啊,再就是讲了mysql优化的explain,这次我们来说说mysql的锁. mysql锁 锁从性能上分为乐观锁( ...

  2. kafka删除弃用的groupid

    登录zookeeper客户端 cd zookeeper-3.4.10 sh zkCli.sh 查看groupid信息 [zk:localhost:2181(CONNECTED) 1] ls /cons ...

  3. pyenv的安装和简单使用

    centos7.4   python2.7 安装pyenv需要的依赖 yum -y install gcc zlib-devel bzip2-devel openssl-devel ncurses-d ...

  4. IT修养-基础篇

    1.科学基础 成为开发人员的过程不尽相同,有的是科班出身,有的是兴趣爱好,还有的是专业机构的培训,在这个过程中,可能全面或者零散甚至没有学习过计算机基础学科,但无论是哪一种,想要成为更高层次的开发人员 ...

  5. selenium自动化测试-浏览器基本操作

    webdriver 通过协议和接口发现DOM中的元素,并实现控制浏览器的行为,例如打开浏览器.控制浏览器大小. 浏览器刷新及浏览器前进.后退等,接下来介绍浏览器的一些基本操作. 1.启动浏览器 dri ...

  6. JAVA线程通信之生产者与消费者

    package cn.test.hf.test3; import java.util.concurrent.locks.Condition;import java.util.concurrent.lo ...

  7. Mysql INSTR函数

    在Mysql中,可以使用INSTR(str,substr)函数,用于在一个字符串(str)中搜索指定的字符(substr),返回找到指定的字符的第一个位置(index),index是从1开始计算,如果 ...

  8. idea设置方法或常量字段上浮显示对应的注释内容

    1.进入idea中,如下图进入设置 如图勾选并设置显示延迟时间 打开文件进行鼠标移动测试 可以看到鼠标移动到字段常量或方法上时显示了对应的注释类容

  9. mybatis 常用的jabcType与javaType对应

    一.jabcType与javaType对应   JDBC Type            Java Type CHAR                 String VARCHAR           ...

  10. JS 生成唯一值UUID

    md5加密new Date()生成的值可能不是唯一的,另一种生成唯一值的方式: getUID: function() { // 获取唯一值 return 'xxxxxxxx-xxxx-4xxx-yxx ...