this的指向

this的指向大致可以分以下4种

1.作为对象的方法调用

2.作为普通函数调用

3.构造器使用

4.Function.prototype.call 和 Function.prototype.apply调用

作为对象的方法调用时 this指向该对象

作为普通函数调用时this指向全局对象,在浏览器的javescript里,这个全局对象是window对象

作为构造器调用时 构造器里的this指向返回的这个函数对象 如果显式的返回一个object类型的对象,那么此次运算结果最终返回这个对象,而不是我们之前期待的this

Function.prototype.call 和 Function.prototype.apply调用时可以动态的改变传入函数的this

   call和apply 的区别

        apply接收二个参数, 第一个指定了函数体内this的指向,第二个是带下标的集合。

        这个集合可以说数组,也可以是类数组。

const func = function(a,b,c){
    return [a,b,c] //输出[1,2,3]
 }
 func.apply(null, [1,2,3]) 

 call 传入的参数不固定,第一个参数指向this,从第二个开始往后,每个参数被依次传入函数

const func = function(a,b,c){
    return [a,b,c] //输出[1,2,3]
 }
 func.call(null, 1,2,3) 

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值