上下文调用模式

上下文调用模式:JS提供给我们的三个方法,而这三个方法的作用是随意控制函数中this的指向

1.函数.call(第一个参数:想让函数中this指向谁,就传谁进来

后面的参数:本身函数需要传递的实参,一个个传递进来即可)

call()的作用:

(1)调用函数

(2)指向函数中this的指向

 <script>
 function fn(x,y){
   console.log(x+y)
   console.log(this)
 }
 fn.call([15,54,68],5,9)
</script>

打印结果:

14   

Array(3)

2.函数.apply(第一个参数:想让函数中this指向谁,就传谁进来,

第二个参数要求传一个数组,数组中包含了要传递的实参)

apply()的作用:

(1)调用函数

(2)指向函数中this的指向

 <script>
 function fn(x,y){
   console.log(x+y)
   console.log(this)
 }
 fn.apply([12,54,68],[11,9])
</script>

打印结果:

20  

Array(3)

3.函数.bind(第一个参数:想让函数中this指向谁,就传谁进来

后面的参数:本身函数需要传递的实参,一个个传递进来即可)

bind()的作用:

(1)克隆当前函数,返回克隆出来的新的函数

(2)新克隆出来的函数,这个函数的this被指向了

 <script>
 function fn(x,y){
   console.log(x+y)
   console.log(this)
 }
 var f=fn.bind([12,54,68],1,9)
 f();
</script>

打印结果:10     

[12,54,68]

 4.上下文调用模式的三个方法的总结

(1)call,allay,这两个方法都会调用函数

(2)call,bind,这两个方法里面的传参方式是一样的

(3)bind ,方法不会调用函数,只会克隆一个新的函数出来

转载于:https://www.cnblogs.com/zhaodz/p/11593361.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值