美文网首页
Jquery$选择器--是如何将DOM封装成jquery对象的2

Jquery$选择器--是如何将DOM封装成jquery对象的2

作者: Wang997 | 来源:发表于2018-07-20 10:20 被阅读0次

前言:

说到jquery不得不说的就是强大的jquery的选择器功能啦。该功能很强大,还单独分离出来sizzle模块供只需用到选择器功能的朋友使用。(该篇先不说jquery选择器的强大功能,先说说jquery是如何将DOM元素封装成jquery对象的)

一、Dom对象和jquery对象

测试

var oBox = document.getElementById('box');

var oBox2 = document.querySelector('#box');

varBox=Box =Box=('#box');

console.log(oBox);

console.log(oBox2);

console.log($Box);

运行结果:

从中我们就可以看出区别了,$()把DOM对象封装成jquery对象,而DOM对象也就保存在jquery[0]中,这也就是为什么我们说的把jquery对象转化成DOM对象只需用jquery[0]或者jquery.get(0)了。

二、模拟jquery--根据id,封装jquery对象

这里先简化一下,看看封装jquery对象的一部分过程

测试

varBox=Box =Box=('#box');

console.log('这是jquery对象');

console.log(公式输入有误/;

match = rquickExpr.exec( selector );

//console.log(match);  //正则匹配找出id的值

if ( !selector ) {  //如果selector为'',null,undefind直接退出操作

return this;

}

elem = document.getElementById(match[2]);

this[0] = elem;

this.context=document;

this.length = 1;

this.selector = selector;

return this;

}

}

jQ.fn.init.prototype = jQ.fn;

window.公式输入有误('#box'));  //输出封装的对象

②输出结果:(火狐浏览器上打开的)

这里需要注意的是,chrome浏览器在显示上有会些不同

jquery显示的是类数组对象形态。

③、解析

对于上面代码有很多看不明白的朋友建议看一下我前面写的文章【jquery源码】开始学习源码之前需要解决的一些问题。

正则匹配我是直接复制了源码中的正则,可以输出该正则处理后的结果来看看。

三、模拟jquery--根据标签名,封装jquery对象

直接上代码

  • 测试1
  • 测试2
  • 测试3
  • 测试4
  • console.log('这是jquery对象');

    var aLi1 = $('li');

    console.log(aLi1);

    console.log('------分界线------');

    (function(window,undefined){

    var jQ = function(selector,context){

    return new jQ.fn.init(selector, context);

    };

    jQ.fn = jQ.prototype = {

    jquery:'2.0.0',    //jquery版本号信息

    constructor: jQ,    //添加构造器属性

    length:0,          //初始length属性

    selector:'',        //初始selector属性

    init: function(selector, context){

    var match, elem;

    if ( !selector ) {  //如果selector为'',null,undefind直接退出操作

    return this;

    }

    elem = document.getElementsByTagName(selector);

    for(var i =0,len=elem.length; i

    this[i] = elem[i];

    }

    this.context=document;

    this.length = elem.length;

    this.selector = selector;

    return this;

    }

    }

    jQ.fn.init.prototype = jQ.fn;

    window.公式输入有误('li'));  //输出封装的对象

    输出结果:

    这里只是单纯的模拟,jq处理起来远远没有那么简单,jquery还进行了大量的判断(下面的文章会继续说这个问题)。还可以在jquery对象中发现prevObject属性,该属性保存的是上一级的查找对象。

    相关文章

    • jQuery 学习笔记(一)

      全文介绍 jQuery 中入口函数 jQuery 对象和 DOM 对象 jQuery 选择器 jQuery 样式操...

    • JQuery - 样式

      Ⅰ、DOM 与 JQuery对象 1. 把jQuery对象转成DOM对象 2. 把DOM对象转成jQuery对象 ...

    • jquery原理和核心方法学习笔记

      1、jquery的实现原理 2、jquery对象和js对象互换 dom 对象转为jquery对象 $(dom) j...

    • JQuery 对象与 DOM对象的转换

      1.JQuery对象转DOM对象 2.DOM对象转JQuery对象

    • JQuery

      JQuery 基础:概念快速入门JQuery对象和JS对象区别与转换选择器DOM操作案例 JQuery 基础: 概...

    • jQuery 基础

      jQuery jQuery操作DOM jQuery的选择器 基本选择器 层级选择器 过滤选择器 jQuery操作样...

    • jQuery

      jQuery jQuery操作DOM jQuery的选择器 基本选择器 层级选择器 过滤选择器 jQuery操作样...

    • jquery对象和dom对象的区别

      DOM对象,即是我们用传统的方法(javascript)获得的对象,jQuery对象即是用jQuery类库的选择器...

    • jQuery快速使用指南

      jQuery 方法解读 和 对象特点通过css选择器字符串 获取jQuery对象通过window、dom对象包装的...

    • jQuery(样式和DOM)

      初识jQuery jQuery选择器 jQuery的属性与样式 DOM DOM节点的复制与替换 jQuery遍历

    网友评论

        本文标题:Jquery$选择器--是如何将DOM封装成jquery对象的2

        本文链接:https://www.haomeiwen.com/subject/oojfmftx.html