JQuery{eq(idx)/get(idx)/$(selector)[idx]}三者关系与区别
JQuery{eq(idx)/get(idx)/$(selector)[idx]}三者关系与区别
ansatsing 发表于1年前
JQuery{eq(idx)/get(idx)/$(selector)[idx]}三者关系与区别
  • 发表于 1年前
  • 阅读 7
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 新注册用户 域名抢购1元起>>>   

            eq()方法返回的是一个JQuery对象,也就是[object Object];

             get()方法返回的是DOM对象,也就是[object HTMLLIElement];

            $(selector)[idx]返回的是DOM对象,也就是[object HTMLLIElement];

我们用一个例子说明一下:

首先引入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>

复制代码

关于JQuery对象与DOM对象的转换可以参考http://blog.csdn.net/jueshengtianya/article/details/8823091

再次点击按钮时,就会呈现如下的画面:

验证完毕,经过这个例子相信大家对于eq()与get()方法会有所了解了。

最后在来个扩展吧,还是基于上面的html

复制代码

<script>
$("#b1").on("click",function(){
      var $obj = $("#ul li");
      var obj1 = $obj.get(1);
      var obj2 = $obj[1];
      if(obj===obj1){
            alert(111);
        }else{
            alert(222);
        }
})
</script>

复制代码

大家可以猜猜看,弹出那个了?

经过本人验证弹出的是111,那么可以得出一个结论:$obj.get(1)和$obj[1],在这里可以互相替换使用。

共有 人打赏支持
粉丝 0
博文 10
码字总数 1716
×
ansatsing
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: