uniq(array)

返回不存在重复值的数组

function classRE(name)

判断classCache中是否已存在name,若存在则取出classCache[name];否则存入该类名的正则表达式至classCache[name]中

function maybeAddPx(name,value)

若name在cssNumber中则返回value;否则返回value+"px"

function defaultDisplay(nodeName)

从elementDisplay中获取该nodeName(即标签类名:a,div,p……)的默认display值;若elementDisplay中不存在nodeName该项,则新建该节点并添加到文档中通过getComputedStyle(element, '').getPropertyValue("display")获取其默认值,若默认为none则设为“block”并存入elementDisplay[nodeName]中

ps:zepto中定义了getComputedStyle=document.defaultView.getComputedStyle

$.each(elements, callback)

若elements是类数组(elements.length 是 number类型),则用for(var i = 0,l=elements.length ; i < l ; i++)来加速循环调用callback

若不是类数组,则使用for in来循环对每个属性调用callback

上述两个循环中一旦callback返回值为false即中断循环

最后返回值均为elements

$.map(elements, callback)

map函数和each函数的优化策略是一样的,只是map返回的是单一对象(elements.length <= 0)或一组数组(elements.length > 0),结果中存放遍历函数的运行结果

zepto.Z(dom, selector)

将dom的原型设为$.fn,以便返回值能调用$.fn的方法

zepto.isZ(object)

判断object的原型是否zepto.Z(zepto.Z.prototype = $.fn)

zepto.init(selector,context)

进入下述其中一条分支,按顺序依次判断

a.若!selector则返回空的zepto collection,也就是zepto.Z()

b.若selector是函数则在DOMContentLoaded后执行

c.若selector已经是Z对象,则返回selector本身

d.若非上述三种情况,则进入下述其中一条分支,按顺序依次判断

d1.若selector是Array,则dom=compact(selector)

d2.若selector是对象:

d21.若isPlainObject(selector)为true,则dom为selector的副本(浅复制)

d22.若isPlainObject(selector)为flase,则dom=selector

令selector = null;

d3.若selector符合fragmentRE(html片段),则dom为根据该片段生成的节点,令selector = null

d4.若存在context,则返回$(context).find(selector),也就是context中的selector节点,此时init函数已经结束

d5.若非上述情况,则dom=zepto.qsa(document, selector),也就是从document中查找符合selector的节点

若符合d1,d2,d3,d5则返回zepto.Z(dom,selector)

zepto.fragment(html, name, properties)

对html进行拓展(若html为"<div/>",则拆分闭合后为"<div></div>")

若name没定义,则通过正则表达式从html中获取name

若name不在containers中,则name = “*”

创建一个container,令其等于containers[name],并使其innerHTML=html;

dom = $.each(slice.call(container.childNodes), function(){
container.removeChild(this)
})

如果isPlainObject(properties)返回true,则另nodes=$(dom),并对nodes设置properties 这3行代码不仅使dom=slice.call(container.childNodes),还清空了container的内容,使container不受污染

最后,返回dom(此时dom是slice.call(container.childNodes), 并不是z集合)

$ = function(selector, context){
    return
zepto.init(selector, context)
  }

此处不直接使用$=zepto.init是因为要对$进行扩展而不会影响zepto.init

Zepto源码笔记(二)的更多相关文章

  1. Zepto源码笔记(一)

    最近在研究Zepto的源码,这是第一篇分析,欢迎大家继续关注,第一次写源码笔记,希望大家多指点指点,第一篇文章由于首次分析原因不会有太多干货,希望后面的文章能成为各位大大心目中的干货. Zepto是一 ...

  2. jQuery源码笔记(二):定义了一些变量和函数 jQuery = function(){}

    笔记(二)也分为三部分: 一. 介绍: 注释说明:v2.0.3版本.Sizzle选择器.MIT软件许可注释中的#的信息索引.查询地址(英文版)匿名函数自执行:window参数及undefined参数意 ...

  3. Tomcat8源码笔记(二)Bootstrap启动

    TOMCAT源码调试入口是Bootstrap类的main方法,我的启动参数VM: -Dcatalina.home=E:/Tomcat_Source_Code/apache-tomcat-8.0.53- ...

  4. Zepto源码笔记(三)

    ps:本文中"组装成成数组"指的是若元素个数大于1则返回数组,若元素只有1个则返回元素本身 以下函数是$.fn该对象的方法 ready(callback) 通过readyRE正则表 ...

  5. jQuery源码笔记——二

    jQuery选择这样返回对象 var jQuery = function( selector, context ) { return new jQuery.fn.init( selector, con ...

  6. Tomcat8源码笔记(三)Catalina加载过程

    之前介绍过 Catalina加载过程是Bootstrap的load调用的  Tomcat8源码笔记(二)Bootstrap启动 按照Catalina的load过程,大致如下: 接下来一步步分析加载过程 ...

  7. zepto源码--核心方法10(位置)--学习笔记

    今天基本上就是zepto学习笔记的最后一篇了,介绍一下有关位置的函数,position, offset, scrollLeft, scrollTop scrollLeft 如果所选取的包装集不存在,则 ...

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

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

  9. Zepto源码分析(二)奇淫技巧总结

    Zepto源码分析(一)核心代码分析 Zepto源码分析(二)奇淫技巧总结 目录 * 前言 * 短路操作符 * 参数重载(参数个数重载) * 参数重载(参数类型重载) * CSS操作 * 获取属性值的 ...

随机推荐

  1. javaWeb实现使用邮箱邮件找回密码功能

    JSP+Jmail+JavaBean 发邮件(转)2010-08-23 18:052007年04月14日 14:32/* * SendMail.java * * Created on 2007年3月3 ...

  2. C# 文件创建时间,修改时间

    System.IO.FileInfo fi = new System.IO.FileInfo(@"D:\site\EKECMS\skin\Grey\default#.html"); ...

  3. c#使用UIA进行模拟点击操作

    之前,我写过一篇c#使用spy进行模拟操作的文章,有朋友在留言中提到了UIA进行操作,今天也使用UIA重新实现一次对vnc窗体的控制测试. 实现目标 在server框内填入192.168.2.200 ...

  4. uva 10036 Problem C: Divisibility

    题意:能否在一个整数序列的每相邻的两项之间添加一个加减号,使得最终结果能被一个给定整数K<=100整除. dp[i][j]表示第i个数取余k为j的布尔值. #include <cstdio ...

  5. linux教程之四

    相信不少想学习linux的新手们正愁不知道看什么linux学习教程好,下面小编给大家收集和整理了几点比较重要的教程,供大家学习,如需想学习更多的话,可到wdlinux学堂寻找更多教程.   linux ...

  6. JavaScript……

    退役了好伤心…… 这几天搞研究性学习写网页版贪吃蛇代码……太蛋疼了 要学javascript,就还要搞AJAX.JQuery.JSON…… 我感觉整个人都不好了

  7. 算法导论(第三版)Exercises2.3(归并排序、二分查找、计算集合中是否有和为X的2个元素)

    2.3-1: 3 9 26 38 41 49 52 59 3 26 41 52   9 38 49 57 3 41   52 26   38 57   9 49 3   41  52  26  38  ...

  8. hadoop2.2.0 MapReduce分区

    package com.my.hadoop.mapreduce.partition; import java.util.HashMap;import java.util.Map; import org ...

  9. 一个安全测试的CheckList

    转自:http://hi.baidu.com/dontcry/item/90c2bc466558c217886d1075 不登录系统,直接输入登录后的页面的URL是否可以访问: 不登录系统,直接输入下 ...

  10. [ES6] When should use Map instead of Object

    Use Maps when keys are unknown until runtime: Map: let recentPosts = new Map(); createPost( newPost, ...