call()
方法使用一个指定的 this 值和单独给出的一个或多个参数来调用一个函数。
语法:
function.call(thisArg, arg1, arg2, ...)
apply()
方法调用一个具有给定this值的函数,以及以一个数组(或类数组对象)的形式提供的参数。
语法:
func.apply(thisArg, [argsArray])
注意:call()
方法的语法和作用与 apply()
方法类似,只有一个区别,就是 call()
方法接受的是一个参数列表,而 apply()
方法接受的是一个包含多个参数的数组。它们的共同点是,都能够改变函数执行时的上下文,将一个对象的方法交给另一个对象来执行,并且是立即执行的。
举例:
function func (a,b,c) {}
func.call(obj, 1,2,3)
// func 接收到的参数实际上是 1,2,3
func.call(obj, [1,2,3])
// func 接收到的参数实际上是 [1,2,3],undefined,undefined
// -------------------------
func.apply(obj, [1,2,3])
// func 接收到的参数实际上是 1,2,3
func.apply(obj, {
0: 1,
1: 2,
2: 3,
length: 3
})
// func 接收到的参数实际上是 1,2,3
bind()
方法创建一个新的函数,在 bind()
被调用时,这个新函数的 this 被指定为 bind()
的第一个参数,而其余参数将作为新函数的参数,供调用时使用。
语法:
Function.bind(thisArg[, arg1[, arg2[, ...]]])
bind 方法 与 apply 和 call 比较类似,也能改变函数体内的 this 指向。不同的是,bind 方法的返回值是函数,并且需要稍后调用,才会执行。而 apply 和 call 则是立即调用。
举例:
function add (a, b) {
return a + b;
}
function sub (a, b) {
return a - b;
}
add.bind(sub, 5, 3); // 这时,并不会返回 8
add.bind(sub, 5, 3)(); // 调用后,返回 8
- 几个关键点:
- call 的第一个参数是 this,后面的参数是 arguments 或其他参数
- apply 的第二个参数必须是数组,内含所有其他参数
- bind 的用法:
(1)
fn.bind(x,y,z)
不会执行 fn,而是会返回一个新的函数
(2)新的函数执行时,会调用 fn,调用形式为 fn.call(x, y, z)
,其中 x 是 this,y 和z 是其他参数