javascipt中this的指向问题记录

一、前言

前端中this的指向一直是令人比较头疼的问题。由于没有弄懂this的指向,导致在学习框架总会出现undefined错误,这次借这个机会梳理一下。

二、this指向的几种情况

  • 在全局作用域中
  • 在函数中
  • 在方法中
  • 在箭头函数中
  • 在事件处理函数中

三、在全局作用域中

image.png

注意:在不同执行环境下的全局作用于中this指向是不一样的,这取决于开发者是如何绑定的。在浏览器执行环境中,this表示Window对象;在node执行环境中,this表示{};在react框架中,this表示undifined。

四、在函数中

image.png

image.png

在函数中,如果没有修改指向,this指向与全局作用域的this指向保持一致。

五、在方法中

在方法中,如果没有修改指向,this指向调用者,谁调用就指向谁。

六、在箭头函数中

image.png

image.png

在箭头函数中,this指向与上一层this保持一致。与上述在函数中的this比较,显然成立。箭头函数常用于方法内部的回调函数中,使this指向与方法内部的this指向保持一致,指向调用方法的对象。

image.png

七、在事件处理函数中

在事件处理函数中,如果是内嵌函数绑定,那么this指向与在函数中this指向保持一致;如果是内嵌方法调用绑定,那么this指向与在方法中this指向保持一致;如果是element.onEvent=function(){}和element.addEventListener(“event”, function(){})绑定,那么this指向触发事件的元素。

© 版权声明
THE END
喜欢就支持一下吧
点赞0

Warning: mysqli_query(): (HY000/3): Error writing file '/tmp/MYst8Wt6' (Errcode: 28 - No space left on device) in /www/wwwroot/583.cn/wp-includes/class-wpdb.php on line 2345
admin的头像-五八三
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

图形验证码
取消
昵称代码图片