apply和call的效果和异同

相同点

1.将第一个传入对象变为函数this的指向,并执行函数

let s = function(){console.log(this)}
let k = {a:123,b:312}

s() //Window 对象
s.apply(k)  // {a:123,b:312} 
s.call(k)   // {a:123,b:312} 

2.将传入的第二个参数,传给函数
 

let c = [1]
let func = function(a){console.log(a)}
func.apply(null,c) //1
func.call(null,c)  //[1]

 

不同点

1.apply的第二个参数只接受数组,传入对象不显示,传入其他报错(call不受限制)
 

let c = {a:1}
let b = [1,2,3]
let k = '123'
let func = function(a){console.log(a)}
func.apply(null,c) //undefined
func.apply(null,b) // 1
func.apply(null,k) // error

2.apply会对传入的第二个参数进行分解,call整个传入

let c = [1,2,3,4]
let func = function(){console.log(arguments)}
func.apply(null,c) //[1,2,3,4]
func.call(null,c)  //[[1,2,3,4]]

//更直观一点
let func = function(){console.log(arguments[0])}
func.apply(null,c) //1
func.call(null,c)  //[1,2,3,4]

如果对arguments不了解,再举个不用arguments的栗子

let c = [1,2,3,4]
let func = function(a,b,c,d){console.log(a,b,c,d)}
func.apply(null,c) //1,2,3,4
func.call(null,c)  //[1,2,3,4] undefined undefined undefined

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值