this指向问题

我今天下午本来想做个就是tr鼠标移出之后过三秒把对应的input添加hiddens类

然后我就这样写了

$('.table>tbody>tr').mouseout(function(){
  var index=$(this).index();
  setTimeout(function(){
  console.log(index);
  console.log($(this));
  $(this).parents('.table').siblings('.check-btn').children('p').eq(index).children('input').addClass('hiddens');
},3000);

然后就一直不能得到我想要的效果

然后我就打印了setTimeout里面的this

发现this指向了window

我去

我本意是想指向tr的呀

然后我就发现可能是闭包了

然后我对闭包也并不熟悉

然后我就看书了

然后我就找到了解答的方案

如下

    $('.table>tbody>tr').mouseout(function(){
                    var index=$(this).index();
                    var that=$(this);
                    setTimeout(function(){
                        console.log(that);
                        that.parents('.table').siblings('.check-btn').children('p').eq(index).children('input').addClass('hiddens');
                    },3000);
                })

看到了吗

用that=$(this)

在setTimeout外面定义

哇撒

然后that就指向了tr

 

 

 

但是这时我又有疑惑了

为什么setTimeout里面this会指向window呢

然后就发现我知识太少了

然后就得到了小伙伴的指导

原来

setTimeout是挂在window上面的全局方法

是不是一目了然就知道了我疑惑setTimeout里面的this指向问题

 

ps:原谅我的知识有限,经过园友的指出,原来这个不是闭包问题,所以我就改正了,谢谢谢谢各位园友,园友的力量是伟大的:

  还有问了一些小伙伴说:闭包是变量的作用域的问题,这个是改变了 this 指向的

 


更多专业前端知识,请上 【猿2048】www.mk2048.com
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值