5-jQuery基本结构分析 工厂函数的实现 伪数组 入口函数参数分析/总结 工具方法的抽取 插件机制

jQuery基本结构分析

  • 结构: 闭包(即时函数)-函数持有了本不属于自己的变量
    • 普通函数也是闭包理解
      • 函数的访问规则-内层可以访问外层的作用域
  • jQuery为什么使用闭包结构
    • 闭包是一个封闭空间, 外层不能访问内层数据, 可以保护框架的代码
    • 把所有的代码封装起来, 只提供了两个全局变量
    • 避免和其他框架产生冲突
  • 参数window
    • 提高性能(缩短代码的查找链)
    • 为什么形参也是window-方便代码压缩(形参替换a,b,c之类的)和混淆
  • 形参undefined-解决兼容性的问题
    • 方便代码压缩
    • undefined在IE浏览器中有不同的表现形式
      • 正常情况下, console.log(undefined = 5555;) //undefined
      • IE9-之前, undefined可以被修改
        • window.undefined = window.undefined //访问window的属性undefined的值(未定义)赋值给window的属性

工厂函数的实现

  • 思考: 框架外部应该如何使用这个框架, 应该如何获取这个框架的功能
  • 外部访问闭包中的数据:
    • 在闭包中返回函数,在这个返回的函数中间接访问闭包中的数据
    • 把闭包中的私有数据(提供给外部的接口)绑定给全局对象window
    • 提供对外的接口

伪数组

  • 伪数组的特点
    1. 本身是对象并非数组
    2. key从0开始, 依次递增-可以允许存在另类的key(但是在处理时会被忽略)
    3. 拥有length属性, 记录key的值
    4. 必需拥有length-1属性(length-1对键值对)
    5. 该对象不是window(window.length记录的iframe标签的个数)
      • 判断某个对象是否是window: obj==window.window
  • 伪数组种类-处理入口函数为伪数组的方法
    1. 系统自带的伪数组
      • 使用[].push.apply(obj,系统自带的伪数组)
    2. 自定义的伪数组
      • 自定义的伪数组在IE9以下(IE9-)会报错, 不能直接用[].push.apply(obj, 自定义伪数组)来转换
      • 伪数组-->先转换成数组-->[].push,apply(obj,数组);
        • 遍历obj-arr.push(obj[i])
        • var arr2 = [].slice.apply(obj); 在把arr2-push进去

入口函数参数分析

  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. 对参数进行类型判断, 根据判断类型的结果分别处理

工具方法的抽取

  • 方法
    1. 工具对象: 多个方法放在一个对象中

    2. 给构造函数添加静态方法(拷贝工具对象的方法-遍历工具对象进行属性拷贝)

       var obj = {name : 'zs',age : 20,friends:['小明','小红']};
       var  obj1 = {};
       // 需求:obj1获取obj的属性
      
       for(var key in obj){
           obj1[key] = obj[key];
       }
      
    3. 给构造函数的原型对象添加原型方法

  • jQuery实现
    • jQ.each(); 添加在构造函数自己身上的静态方法

    • jQ().each(); 添加在构造函数对应的原型对象上面的原型方法

        XDYQuery.prototype.extend  = XDYQuery.extend = function (obj) {
            for(var i in obj)
            {
                this[i] = obj[i];
            }
        }
        //静态方法调用-把工具对象直接作为参数传进去
        XDYQuery.extend(  {  //...  }  );
      

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

  • 参数:
    • 如果没有传递参数:获取页面中所有指定的标签存储在数组中返回 == toArray方法
    • 传递参数
      • 参数是正数
      • 参数是负数 如果是-1,表示获取倒数第一个(获取所有指定标签.length+负值索引)

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

  • 参数:
    • 没有参数(判断arguments.length == 0):返回一个空的jQ对象(不是this)
    • 传递参数
      • 参数是正数 ==>$(get)
      • 参数是负数

each()实现思路

  • each方法的使用

    1. jQ.each(obj | arr,fn(key,value){.....})
    2. jQ().each(fn(key,value){.....})
      • 作用: 遍历对象 | 数组 | 伪数组, 每循环一次就把当前的键值对(索引/元素)作为参数传递给后面的回调函数, 并且执行回调函数中的代码
  • jQuery中each()的实现思路

    1. 遍历对象 | 数组 | 伪数组
      • [1] 遍历对象 ==> for..in
      • [2] 遍历数组 ==> for | for..in (不推荐:包括原型成员) ? |forEach
      • 遍历伪数组 ==> for..in | for
    2. 调用回调函数
      • 中断循环(遍历中判回调函数的返回值是否为假, 条件为真就结束循环)
      • 回调函数中的this指向的是当前循环的value值(回调函数借用call方法设置this指向value值)

jQuery中map()实现思路

  • jQ.map(arr,fn(index,value))
    • 作用:变量数组,在回调函数中对数组进行处理(放大|过滤),把回调函数中的返回值收集组成一个新的数组
  • 实现思路
    • 初始化一个空的数组
    • 遍历传进来的数组, 调用回调函数拿到遍历数组的索引/value值, push到空数组中
    • return空数组

jQuery中remove()实现思路

  • 遍历jQ实例对象
  • 每循环一次,就把当前的标签删掉

插件机制

  • 在jQuery框架的基础上, 再提供一个新的js文件, 这个js中新增一些功能
  • js文件命名: jQuery-名称.js
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341