前言:说到jquery不得不说的就是强大的jquery的选择器功能啦。该功能很强大,还单独分离出来sizzle模块供只需用到选择器功能的朋友使用。(该篇先不说jquery选择器的强大功能,先说说jquery是如何将dom元素封装成jquery对象的)
一、dom对象和jquery对象
<body><script src="https://cdn.bootcss.com/jquery/2.0.0/jquery.min.js"></script><p id="box">测试</p><script> var obox = document.getelementbyid('box'); var obox2 = document.queryselector('#box'); var $box = $('#box'); console.log(obox); console.log(obox2); console.log($box);</script></body></html>
运行结果:
从中我们就可以看出区别了,$()把dom对象封装成jquery对象,而dom对象也就保存在jquery[0]中,这也就是为什么我们说的把jquery对象转化成dom对象只需用jquery[0]或者jquery.get(0)了。
二、模拟jquery--根据id,封装jquery对象
这里先简化一下,看看封装jquery对象的一部分过程
<body><script src="https://cdn.bootcss.com/jquery/2.0.0/jquery.min.js"></script><p id="box">测试</p><script> var $box = $('#box'); console.log('这是jquery对象'); console.log($box); console.log('------分界线------'); (function(window,undefined){ var jq = function(selector){ return new jq.fn.init(selector); }; jq.fn = jq.prototype = { jquery:'2.0.0', //jquery版本号信息 constructor: jq, //添加构造器属性 length:0, //初始length属性 selector:'', //初始selector属性 init: function(selector){ var match, elem, rquickexpr = /^(?:\s*(<[\w\w]+>)[^>]*|#([\w-]*))$/; 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.$$ = jq; })( window ); console.log('这是模拟的对象'); console.log($$('#box')); //输出封装的对象</script></body>
②输出结果:(火狐浏览器上打开的)
这里需要注意的是,chrome浏览器在显示上有会些不同
jquery显示的是类数组对象形态。
③、解析
对于上面代码有很多看不明白的朋友建议看一下我前面写的文章【jquery源码】开始学习源码之前需要解决的一些问题。
正则匹配我是直接复制了源码中的正则,可以输出该正则处理后的结果来看看。
三、模拟jquery--根据标签名,封装jquery对象
直接上代码
<body><ul class="list"> <li>测试1</li> <li>测试2</li> <li>测试3</li> <li>测试4</li></ul><script> 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<len; i++){ this[i] = elem[i]; } this.context=document; this.length = elem.length; this.selector = selector; return this; } } jq.fn.init.prototype = jq.fn; window.$$ = jq; })( window ); console.log('这是模拟的对象'); console.log($$('li')); //输出封装的对象</script></body>
输出结果:
这里只是单纯的模拟,jq处理起来远远没有那么简单,jquery还进行了大量的判断(下面的文章会继续说这个问题)。还可以在jquery对象中发现prevobject属性,该属性保存的是上一级的查找对象。看看下面的例子就能明白了。
<body><script src="https://cdn.bootcss.com/jquery/2.0.0/jquery.min.js"></script><ul class="list"> <li>测试1</li> <li>测试2</li> <li>测试3</li> <li>测试4</li></ul><script> var ali1 = $('li'); console.log(ali1); var ali2 = $('li','.list'); console.log(ali2); var ali3 = $('.list').find('li'); console.log(ali3);</script></body>
本文讲解了$选择器--是如何将dom封装成jquery对象,更多相关内容请关注。
相关推荐:
css3动画导航栏3d
requests库的基本使用
前端调用微信支付接口
以上就是$选择器--是如何将dom封装成jquery对象的详细内容。