javascript中call,apply,bind有什么不同?

2018-12-07  本文已影响0人  马祥赛

call,apply,bind三者都与this绑定(显示绑定)相关,改变this指向,但又有细微区别
看下面代码:

function foo () {
  console.log(this.a);
}
var obj= {
  a: 2
};
foo(); //  undefined(非严格模式)
foo.call(obj); // 2
foo.apply(obj); // 2
foo.bind(obj); // 不会执行

1、可以看出,call和apply执行后,会改变foo的this指向,指向传入的第一个参数,而bind调用后不会执行foo函数(其实bind是会返回一个指向obj的新函数)

function foo (a, b) {
   console.log(a + b)
}
foo.call(null, 1, 2) // 3
foo.apply(null, [1, 2]) // 3
foo.bind(null, 1, 2) // 不会立即执行
var bar = foo.bind(null, 1, 2)
bar() // 3

2、可以看出,call和apply调用的参数也有所不同,call和apply第一个参数是相同的,不同在于后面的参数,call可以有多个,apply只有一个,并且是以数组的形式传入;从传入参数的角度来看,bind和call是一样的

3、其实bind还有一个功能(把除了第一个参数之外的其余参数都传给下层函数)

function foo (a, b) {
  console.log(a + b)
}
var bar = foo.bind(null, 1)
bar(2) // 3
上一篇 下一篇

猜你喜欢

热点阅读