call, apply 和 bind 方法

Posted cc-freiheit

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了call, apply 和 bind 方法相关的知识,希望对你有一定的参考价值。

  我们知道,每个函数在调用的时候会产生一个执行上下文环境,而这个执行上下文环境中包含了诸如 this 等等信息。即当我们调用函数的时候,内部的 this 已经明确地隐式绑定到了某一个对象上。如果我们希望更换 this 的指向,我们该如何更改?

  call/apply/bind 这三个函数能够满足我们的需要。

 

一个示例:

var common = ‘common‘;
var name = ‘global‘;
var obj = {
  name: ‘obj‘
}

function fn(params) {
  console.log(params + ‘ ‘ + this.name);
}

fn(common) // common global
fn.call(obj, common) // common obj

   我们可以看到,通过 call(),函数内部的 this指向了 obj 对象。

 

call/apply

// 素材函数
var func = function(arg1, arg2) {
     
};

  具体如下:

func.call(yourObj, arg1, arg2);
func.apply(yourObj, [arg1, arg2]);

  所以我们可以看出,apply 和 call 在功能上完全一致,仅仅是传参方式不一致,这样的好处是在传参个数不一定时,可以使用 apply。比如:

// 定义一个 log 方法,让它可以代理 console.log 方法

function log(){
  console.log.apply(console, arguments);
};
log(1);    //1
log(1,2);    //1 2

 

  当然,在使用 call/apply 的时候,原函数是立即执行的。

 

bind

  func.bind(yourObj,xxx,xxx) 执行之后会返回一个新函数,是 func 函数的副本,不同的是新函数内部 this 永远指向 yourObj,当然这意味着在调用 bind 完成绑定之后,需要手动执行一下这个新函数。

  其它用法/功能大致与 call 一致,不过在参数传递上有些许不一致:

function fn(a, b, c) {
    console.log(a, b, c);
}
var newFn = fn.bind(null, ‘Dot‘);

fn(‘A‘, ‘B‘, ‘C‘);            // A B C
newFn(‘A‘, ‘B‘, ‘C‘);           // Dot A B
newFn(‘B‘, ‘C‘);                // Dot B C

   可以看到,我们在 bind() 的时候传入了一个参数,新方法的实参都是在 bind 中参数的基础上在往后排。

 

以上是关于call, apply 和 bind 方法的主要内容,如果未能解决你的问题,请参考以下文章

call apply bind

js中的call()apply()和bind()方法的区别

bind() call() apply()总结

js中的call,apply,bind区别

call() apply() bind()方法的作用和区别!

call() , apply() , bind() 方法,