理解JavaScript中的call,apply和bind方法

前言

js中的call(), apply()bind()Function.prototype下的方法,都是用于改变函数运行时上下文,最终的返回值是你调用的方法的返回值,若该方法没有返回值,则返回undefined。这几个方法很好地体现了js函数式语言特性,在js中几乎每一次编写函数式语言风格的代码,都离不开call和apply,可以熟练运用它们,是真正成为一名jser程序员的重要一步。javascript

apply()

使用 apply, 你能够继承其余对象的方法:java

var max = Math.max.apply(null, [1, 2, 3, 4, 5]);
console.log(max); // 输出5

注意这里apply()的第一个参数是null,在非严格模式下,第一个参数为null或者undefined时会自动替换为指向全局对象,
apply()的第二个参数为数组或类数组。程序员

call()

call()apply()的一颗语法糖,做用和 apply() 同样,一样可实现继承,惟一的区别就在于call()接收的是参数列表,而apply()则接收参数数组。数组

var max = Math.max.call(null, 1, 2, 3, 4, 5);
console.log(max); // 输出5

bind()

bind()的做用与call()apply()同样,都是能够改变函数运行时上下文,区别是call()apply()在调用函数以后会当即执行,而bind()方法调用并改变函数运行时上下文后,返回一个新的函数,供咱们须要时再调用。app

var person = {
  name: 'person',
  getName: function() {
    return this.name;
  }
}
var boy = {
   name: 'twy'
}
// bind()返回一个新函数,供之后调
var getName = person.getName.bind(boy);

// 如今调用
console.log(getName());    // 输出wy

apply()模拟实现bind()函数

Function.prototype.bind = function(context) {
  // 保存调用函数的引用,这里是getName()
  var self = this;
  // 返回一个新函数
  return function(){
    return self.apply(context, arguments);
  }
}
var person = {
  name: 'twy'
}
var getName = function(){
  console.info(this.name);
}.bind(person);
// 执行bind()方法内返回的新函数
getName();

在返回的新函数内部,self.apply(context, arguments)才是执行原来的getName函数,至关于执行getName.apply(person);this

如何选用

  • 若是不须要关心具体有多少参数被传入函数,选用apply()
  • 若是肯定函数可接收多少个参数,而且想一目了然表达形参和实参的对应关系,用call()
  • 若是咱们想要未来再调用方法,不需当即获得函数返回结果,则使用bind();

总结

  • call()apply()bind()都是用来改变函数执行时的上下文,可借助它们实现继承;
  • call()apply()惟一区别是参数不同,call()apply()的语法糖;
  • bind()是返回一个新函数,供之后调用,而apply()call()是当即调用。
相关文章
相关标签/搜索