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

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

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

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

1 obj1.call(obj2,a,b);
2 //等价于
3 if(obj2!==null){
4     obj1.this=obj2;
5     }else{
6     obj1.this=window;
7 }
8 obj1(a,b);

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

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

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

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

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

4.一个例子

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

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

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

 

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

posted @ 2016-12-13 00:03  叶文翔  阅读(1961)  评论(0编辑  收藏  举报