js的this指向问题

需要注意的几点
1)最终this指向的是最后掉用它的对象
2)window是js的全局对象
3)普通的函数、定时器(setTimeout)中的this均指向window
如何改变this的指向
1)call():call方法第一个参数是要绑定给this的值,后面传入的是一个参数列表。当第一个参数为null、undefined的时候,默认this指向window。
2)apply():apply也接受两个参数,第一个参数是要绑定给this的值,但是第二个参数则是一个参数数组。当第一个参数为null、undefined的时候,默认this指向window。

关于参数数组与参数列表,下一篇会提到

3)bind():bind方法与call方法其实很类似,第一个参数是this的指向,第二个是开始接受的参数列表。它与call的区别在于它的返回值,以及对接受的参数列表的使用。
bind返回值是函数
bind方法不会立即调用,而是返回一个改变了上下文this后的函数。原函数的this并没有被改变,依旧指向全局对象window。
如果想让bind直接调用的话,在bind()方法后再加对“()”即可,代表着立即调用。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值