关于jQuery中$(‘ ‘)和$(‘ ‘).get(0)的坑(新手要看!)

关于jQuery中$ (’ ‘)和$(’ ‘).get(0)的坑/为什么 $(’ ')后面要加get(0)(新手要看!)

傻傻分不清$ (’ ‘)和$(’ ').get(0)

javascript一直用的原生敲的,最近出去实习,公司要求用jquery来写,这样兼容性更好点。然后我就踩到了坑,为什么有的地方用$ (’ ‘)就能进行节点操作有的地方只能用$(’ ').get(0)才能获取节点并进行节点操作?

查看案例

首先我们用click点击事件为例,看个小例子了解一下:

<body>
    <button id="btn1">按钮一</button>
    <button id="btn2">按钮二</button>

    <script>
        $('#btn1').onclick=function () {
            console.log("按钮一被点击到了!")
        }
        $('#btn2').click(function () {
            console.log("按钮二被点击到了!")
        })
     </script>
</body>
</html>

现在我们对两个按钮依次进行点击,并查看控制台,发现只有按钮二的js执行了,这是为什么呢?
在这里插入图片描述

现在我们尝试对按钮一的js代码做修改

        $('#btn1').get(0).onclick=function () {
            console.log("按钮一被点击到了!")
        }

然后我们再到浏览器看效果
在这里插入图片描述
这下两个按钮都被点击到了,写多了原生js的我充满了疑问,这是为啥???(当然菜是原罪)
我上网搜了一下,发现对这个的解释模棱两可,可能很多人直接学的jquery没有遇到这个问题吧。然后我研究了起来…

追根溯源

首先在控制台打印一下$ (’ ‘)和$(’ ').get(0)各得到的是什么吧!!!
在这里插入图片描述
在这里看到第一个红框框返回的是jquery筛选出来的符合要求的对象数组,第二个返回的是我们想要的dom节点!

仔细研究不难想象,获取到$ (’ ‘)数组的第一个元素不就是===$(’ ').get(0)吗???

然后我又百度了一下,找到了原因:
在这里插入图片描述

  $(' ').get(0) .onclick这里对元素的事件绑定是采用**js普通(原生)**的方式,所以要获取其数组中真正对象后,才能进行click事件。

说明白点就是,jquery本来就是封装好的js库,里面已经规定好了操作DOM方法,我们用jquery的方法来写才能实现。而$(’ ').get(0) 后面其实是自己写的jquery错误了!那其实是半jquery半原生js的四不像写法!!!

回顾

再看一个例子体会一下

<style>
    *{
        margin: 0;
        padding: 0;
    }
    .box1{
        width: 100px;
        height: 100px;
        background-color: pink;
        position: absolute;
        top: 0px;
    }
    .box2{
        width: 100px;
        height: 100px;
        background-color:olivedrab;
        position: absolute;
        top: 100px;
    }
</style>
<body>
<div class="box1"></div>
<div class="box2"></div>

先看一下初始效果
在这里插入图片描述
下面看下js部分对比

    <script>
        //正确的jquery的写法              
        //能运行
          $('.box1').css('left','20px')
        //四不像写法  前面jquery 后面原生写法
        //能运行
          $('.box2').get(0).style.left='40px';
        //错误的jquery的写法              
        //不能运行
          $('.box2').style.left='40px';
    </script>

在这里插入图片描述

结束语

看完这个,是否你跟我一样对于为什么 $(’ ')后面要加get(0)多少有点明白了呢?

keleinclude_原创,如转载请标明来处!!!

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值