对call() apply() 方法的简单理解

时间:2021-03-28 19:08:36

  真的是非常简单的理解,我知道的并不多,在网上查找了很多的资料,还是只能了解一点皮毛,下面来整理出来,方便以后深入的去学习,也是对目前知道的知识点的巩固。

整理一些网上的经典解答:

1.一句话区分call 和apply

obj1.call(obj2,arg1,arg2,arg3) == obj1.apply(obj2,arguments) == obj2.foo(arg1,arg2,arg3)

thisA.functionA.apply(thisB,[arg1,arg2,...]) == thisA.functionA.call(thisB,arg1,arg2,...) == thisB.functionA(arg1,arg2,...)

  • obj2如果为空则this指向window对象
  • call 和apply的区别在于:call接的参数是固定的,按照顺序输入。apply接收的参数是一个数组。
  • 什么时候使用call或者apply?当参数是固定的时候一般使用call,如果参数不确定或者参数是一个数组时需要使用apply.
  • 上面的话理解成 obj2调用obj1的方法。对象thisB调用thisA的functionA方法

2.理解obj2如果为空则this指向window

 obj1.call(obj2,a,b);
//等价于
if(obj2!==null){
obj1.this=obj2;
}else{
obj1.this=window;
}
obj1(a,b);

3.摘自javascript高级程序书本中的代码

 var values = [1,2,3,4,5,6,9];
var max = Math.max.apply(Math,values);
console.log(max);//

这里Math当作apply()的第一个参数我无法理解,max()方法是Math对象下面的一个方法,values为一个数组对象,需要去借用Math对象下面的max()方法。

 var values = [1,2,3,4,5,6,9];
var max = Math.max.apply(Array,values);
console.log(max);//
 var values = [1,2,3,4,5,6,9];
var max = Math.max.apply(this,values);
console.log(max);//

发现用Array或者this代替 Math尽然都会输出9.

4.一个例子

call和apply可以用来重新定义函数的执行环境,也就是this的指向

 function changgeStyle(attr,value){
this.style[attr] = value;
}
var box = document.getElementById("box");
window.changgeStyle.call(box,"height","200px");

changgeStyle()为window对象下面的方法,那么如何把window对象的方法转移到box对象上呢,通过动态的改变this的指向,也就是相当于借用window.changgeStyle()的方法,通过call方法把 window.changgeStyle("height","200px")变成了box.changgeStyle("height","200px").

总结:就是自己没有的属性或者方法,通过改变函数的执行环境(this的指向),或者通俗点来说就是借用别人的属性或者方法来执行操作。