Web前端之路让前端飞

读zepto核心源码学习JS笔记(1)--整体框架

2017-06-08  本文已影响88人  一二三kkxx

一 整体结构

(function(global,factory){
    if(typeof define === 'function' && define.amd)
        define(function(){return factory(global)})
    else
        factory(global)
}(this,function(window){
    return Zepto
}))
var Zepto =(function(){})()
//将Zepto赋值给window.Zepto;这样其他地方就可以调用zepto的方法了
window.Zepto = Zepto
//当$变量未被占用时,将Zepto赋值给$
window.$ === undefined && (window.$ = Zepto)
    * 知道了$;我们再去找$();此函数的返回值为zepto.init
    ```java
        $ = function(selector, context){
            return zepto.init(selector, context)
       }
    ```
    * 同样,我们接着去找zepto.init()函数,返回值为zepto.Z()
    ```java
    zepto.init = function(selector, context) {
          ...
          return zepto.Z(dom, selector)
    }
    ```
    * 再接着找zepto.Z();返回值为Z函数的实例化
    ```java
    zepto.Z = function(dom, selector) {
        return new Z(dom, selector)
    }
    ```
    * 最后找Z函数;
    ```java
    function Z(dom, selector) {
      var i, len = dom ? dom.length : 0
      for (i = 0; i < len; i++) this[i] = dom[i]
      this.length = len
      this.selector = selector || ''
    }
    ```


###二 分析
大致的流程如上,下面我根据以上的过程去分析代码.

以下为zepto源码节选:
```javascript
$ = function(selector, context){
    return zepto.init(selector, context)
}
zepto.init = function(selector, context) {
    var dom
    if (!selector) return zepto.Z()
    else if (typeof selector == 'string') {
      selector = selector.trim()
      if (selector[0] == '<' && fragmentRE.test(selector))
        dom = zepto.fragment(selector, RegExp.$1, context), selector = null
      else if (context !== undefined) return $(context).find(selector)
      else dom = zepto.qsa(document, selector)
    }
    else if (isFunction(selector)) return $(document).ready(selector)
    else if (zepto.isZ(selector)) return selector
    else {
      if (isArray(selector)) dom = compact(selector)
      else if (isObject(selector))
        dom = [selector], selector = null
      else if (fragmentRE.test(selector))
        dom = zepto.fragment(selector.trim(), RegExp.$1, context), selector = null
      else if (context !== undefined) return $(context).find(selector)
      else dom = zepto.qsa(document, selector)
    }
    return zepto.Z(dom, selector)
}

根据以上代码,可以将zepto.init()函数分为以下几种情况:

qqqq.png
上一篇下一篇

猜你喜欢

热点阅读