问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

谁能举例说明一下吗? 1,dom对象怎么转换jquery对象 2,jquery对象怎么转换dom对

发布网友 发布时间:2022-04-19 22:27

我来回答

2个回答

懂视网 时间:2022-04-20 02:48

前言:说到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*(<[wW]+>)[^>]*|#([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对象,更多相关内容请关注Gxl网。

相关推荐:

css3动画导航栏3D

requests库的基本使用

前端调用微信支付接口

热心网友 时间:2022-04-19 23:56

html代码:

<div id="div1">这是一个层</div>

js代码:

//使用dom对象操作层
var div=document.getElementById("div1");
//这是dom对象
div.innerHTML="层的内容发生改变";
//使用工厂函数将dom对象转换为jQuery对象
$(div).html("这样也变");


//使用jQuery对象操作层
var $div1=$("#div1");
//这是jQuery对象操作层
$div1.html("层的内容发生改变");
//将jQuery对象转换为dom对象
#div1[0].innerHTML="这样也变";

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
是选诺顿杀毒软件好还是NOD32好? 诺顿好还是NOD32好???请高手指点 诺顿安全软件和ESET NOD32安全软件相比,谁的防护.杀毒更强,功能更多... 诺顿和NOD32这两个杀毒软件哪个比较好? 什么是土地二次抵押 "口似含莲,乾姜之手"是什么意思? 乾姜的意思是什么 都说Pinnacle Food公司各方面做的好,有对这家了解的吗 空调蒸发箱多久清洗一次 空调蒸发箱需要清洗吗 苹果xr流量设置 2022年参加北京冬奥会的国家有哪些? 2022年北京冬奥会,有多少个国家参加?参加项目最多的是哪些国家? 北京冬奥会几个国家参加? 北京冬奥会参加的国家有多少? 北京冬奥会几个国家? 举办冬奥会的国家有哪些? 为什么才是男朋友,就会出轨? 男朋友为什么会出轨? 北京冬奥会有多少个国家参加? 男朋友出轨是为什么 2022年北京冬奥会参赛国家有哪些? 男朋友为什么总是出轨? 哪些国家参加北京冬奥会? 北京冬奥会有多少个国家/地区参加? 为什么谈了七年的男朋友会出轨一个比我丑的女人? 2022北京冬奥会有多少个国家参加? 为什么看起来那么好的男朋友会出轨 北京冬奥会参加的国家有哪些? 想不明白谈了七年的男朋友为什么会出轨一个比我丑比我矮脾气比我差的女人? 中国冬奥会有多少国家参加? 长相和狗相似的动物是什么 怎么分辨泰迪犬和红贵狗呢? 十大犬里有没有泰迪犬 鸸鹋油作用 与效果是什么? 鸸鹋油的功效及作用有哪些啊?有没有人愿意分享下心得的 鼎舒堂鸸鹋油霜和鼎盛堂鸸鹋油区别? 在晒图中点击小程序后,按着就在搜索木兰中输入“嗨图”。这一步如何操作?_百度问一问 律师做法律顾问中有哪些风险需要避免 嗨~亲。微信图片发生变化这种的如何破解?因为我亲戚有遇到过这样的*。也不知道怎么办才好 我学法律的,又怕律师法务工作承担风险太大,一不小心说错话给别人造成巨大损失,怎么办?我会不会饿死 微信图片和链接打不开,看不了 关系型营销渠道的介绍 关于美食的问卷调查该怎么写 营销分为直接渠道和间接渠道,各适合哪些产品?各有什么优缺点... 微信上的照片一段时间打不开了,怎么回事 关系型营销策略有哪些? 微信聊了两个月男生突然给你发 嗨!微信女友 晚上好 啥意思啊? 关于家乡美食的问卷调查该涉及哪些问题 各色美食调查问卷 帮我设计一个关于美食的研究性学习的调查问卷