我爱编程

5-jQuery基本结构分析 工厂函数的实现 伪数组 入口函数参

2017-12-13  本文已影响0人  前端雨

jQuery基本结构分析

工厂函数的实现

伪数组

入口函数参数分析

  1. 参数判断为假的情况

    • 返回空的jQuery实例对象
  2. 参数是字符串(选择器)

    • 根据选择器获取页面中所有指定的标签,并且保存到实例对象中返回
  3. 参数是字符串(标签)

    • 把参数中所有的一级标签保存到实例对象中返回,key从0开始一次递增,这些标签作为key对应的value值保存的
  4. 参数是数组

    • 把数组中所有元素依次取出, 保存为jQ实例对象的键值对返回(key从0开始递增, 数组中的元素作为对应的value值)
  5. 参数是伪数组(结构类似于数组)

    • 把伪数组中所有的value值依次取出, 保存jQ实例对象的键值对返回(key从0开始递增, value作为对应key的value值)
  6. 参数是对象

    • 会把参数(对象)作为整体保存为key为0对应的value值, 返回jQ实例对象
  7. 参数是DOM标签(对象)

    • 会把参数(DOM对象)作为整体保存为key为0对应的value值, 返回jQ实例对象
  8. 参数是非零数字

    • 会把参数(数字)作为整体保存在key为0对应的value值, 返回jQ实例对象
  9. 布尔类型的值: 同8.

  10. 函数==监听页面的加载DOM

    • document.addEventListener(要监听的事件, 事件发生后的回调函数)
      • 不兼容IE9-, 会报错
      • 参数一: DOMContentLoaded 表示DOM加载完毕
    • 使用document.attachEvent()兼容IE9以下浏览器
      • 参数
        1. 要监听的状态(固定: onreadystatechange)
        2. 事件发生后的回调函数

入口函数参数分析-总结

  1. 条件判断为假: 返回空的jQ实例对象
  2. 字符串(选择器 | 标签)
  3. 数组或者伪数组:
  4. 对象 | DOM节点 | true | 数字(非0): 会把传入的参数保存为key为0对应的value值, 返回
  5. 函数(待处理)
  6. 思考init方法内部的实现逻辑
    1. 对参数进行类型判断, 根据判断类型的结果分别处理

工具方法的抽取

get(): 获取指定索引对应的标签返回

eq(): 获取指定索引对应的标签并且包装成jQ对象返回

each()实现思路

jQuery中map()实现思路

jQuery中remove()实现思路

插件机制

上一篇 下一篇

猜你喜欢

热点阅读