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
网友评论