函数调用
普通调用:this指向Window(在严格模式下,this指向undefined)
-
宽松模式
image.png
-
严格模式
image.png
隐示调用:this指向调用它的对象
data:image/s3,"s3://crabby-images/f1da3/f1da33b387459c15d1615e07abb06bff7257053c" alt=""
显示调用:this指向call,aplay,bind的第一个参数
data:image/s3,"s3://crabby-images/5f3b5/5f3b549691999c61a25cdbcc36517177b7c861de" alt=""
new(构造调用):this指向构造出来的实例对象
data:image/s3,"s3://crabby-images/c145f/c145f3d3eba59618eeebb04feb43f7e444cab583" alt=""
回调函数
事件回调函数:this指向绑定事件的DOM对象
data:image/s3,"s3://crabby-images/f7909/f7909a85a74904117efc93ffb867e5dbf076d5d5" alt=""
data:image/s3,"s3://crabby-images/15dff/15dff635510e7c61cc8d3856c946924f8ec485b6" alt=""
普通回调函数(定时器,数组方法):this指向Window(在严格模式下,this指向undefined)
data:image/s3,"s3://crabby-images/dad1d/dad1d4a13047663f030cea43c11f5307eadd5fdd" alt="image.png"
箭头函数
箭头函数:this指向离箭头函数最近的那个包裹函数的this,如果没有就指向Window
data:image/s3,"s3://crabby-images/289d2/289d2cd70cfe839e6ce7f5b7d7f32fef160efc8e" alt=""
react,vue中的生命周期函数
生命周期函数的this指向组件对象
react中的自定义函数this指向undefined
data:image/s3,"s3://crabby-images/e577d/e577d010c3caa1e1eee90f0e8cdbdc1779e275af" alt=""
data:image/s3,"s3://crabby-images/36a97/36a97a37630dd9edb81e32ecc6e5fab1dd8ed8fe" alt=""
** 注意:如果把handleClick()改为箭头函数,那么它的this指向组件对象,因为箭头函数的this指向包裹它的函数的this
ES6类中的方法
this指向实例对象
网友评论