这篇文章给大家分享的是有关jquery中eq()和get()有哪些区别的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
区别:1、eq()方法返回的是jquery对象,而get()方法返回的是js对象;2、eq方法可以直接和其他jquery方法配合使用,而get()方法不能直接配合使用,需要先将返回值转为jquery对象才可使用jquery方法。
本教程操作环境:windows7系统、jquery1.10.2版本、Dell G3电脑。
jquery中eq()和get()的区别
之前使用eq和get方法都是随意而为,却没深究其中的区别:
eq方法返回的是jquery对象,而get方法返回的是js对象;jquery对象可以使用jquery方法,而js对象却只能使用js原生的方法,但是js对象可以转换成jquery对象再使用jquery方法即可;例如:访问某个元素的backcolor:
①使用eq方法:$("dv").eq(0).css("backcolor")
②使用get方法:$("dv").get(0).style.backcolor
我们用一个例子说明一下:
首先引入JQuery库文件,
html
<body> <ul id="ul"> <li>item1</li> <li>item2</li> <li>item3</li> </ul> <input type="button" value="click" id="b1"> </body>
js
<script> $("#b1").on("click",function(){ var $obj = $("#ul li"); $obj.eq(1).css("color","yellow"); $obj.get(2).css("color","red"); }) </script>
此时,点击按钮第二个li,即item2字体变为黄色,但是item3没有变为红色,且报如下错误:
报错的意思是,$obj没有get()方法,因为它是一个DOM对象组成的数组,它是没有get()方法,那么我们怎样把它变为JQuery对象了?
只需将$obj.get(2)改为$($obj.get(2))即可,
<script> $("#b1").on("click",function(){ var $obj = $("#ul li"); $obj.eq(1).css("color","yellow"); $($obj.get(2)).css("color","red"); }) </script>
再次点击按钮时,就会呈现如下的画面:
验证完毕,经过这个例子相信大家对于eq()与get()方法会有所了解了。
最后在来个扩展吧,还是基于上面的html
<script> $("#b1").on("click",function(){ var $obj = $("#ul li"); var obj1 = $obj.get(1); var obj2 = $obj[1]; if(obj2===obj1){ alert(111); }else{ alert(222); } }) </script>
大家可以猜猜看,弹出那个了?
经过本人验证弹出的是111,那么可以得出一个结论:$obj.get(1
)和$obj[1]
,在这里可以互相替换使用。
jquery对象和Dom对象相互转换方法:
1.jquery对象——>Dom对象:
有两种方式:
①jquery对象.get(0)
例如:
var v = $("#id").get(0);//Dom对象
②jquery对象[0]
例如:
var v = $("#id")[0];//Dom对象
2.Dom对象——>jquery对象:
$(Dom对象),例如:
var $v =$(document.getelementbyid("id"));//jquery对象
感谢各位的阅读!关于“jquery中eq()和get()有哪些区别”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。