this指向改变的问题

一直在写后台,前端都是同事搞的,对细节上的东西很少研究,一直觉得能达到需求就行,没想到的是jQuery用了那么多,还不懂this指向的道理。

源自一次查看同事写的接口时发现的。

 $.ajax({type: 'POST',
         url: "/URL/",
         data: dat,
         success:function(reslut){
             $(this).prevAll('p').css("text-decoration","line-through");
         }.bind(this)
         });

一直以来我是这样用的

 var _this = $(this);
$.ajax({type: 'POST',
         url: "/URL/",
         data: dat,
         success:function(reslut){
             _this.prevAll('p').css("text-decoration","line-through");
         }
         });

我知道这两种用法都可以,于是我内心就发出了疑问,我知道请求发送成功的function中不能直接使用$(this),但是我不知道为什么,查阅了资料发现是this指向的问题,在请求成功的function中 使用log就可以看到此时 this是指向window的,基础还是不行,多加学习。

点击这里看 查阅文章,这个写的比较详细,讲了this指向改变的问题

猜你喜欢

转载自blog.csdn.net/x15037308498/article/details/83831508