ECMAScript的Call()与Apply()

ECMAScript的Call()与apply()两个方法,call与apply的第一个参数都是需要调用的函数对象,在函数体内这个参数就是this的值,剩余的参数是需要传递给函数的值。

call与apply都是用来改变this的指向,不同就是call传的值可以是任意的,当第一个参数为null、undefined的时候,默认指向window;而apply传的剩余值必须为数组。

例如:function add(a, b) { return a + b; }

function sub(a, b) { return a – b; }

/*apply用法

* var a1 = sub.apply(add, [4, 2]);

*var a2= add.apply(sub, [4, 2]);  

*/

var a1 = sub.call(add, 4, 2);

var a2= add.call(sub, 4, 2);

输出:a1=2  a2=6


sub.call(add, args1,args2);即add调用sub方法


add.call(sub, args1,args2);即sub应用add方法


JS中attribute和property的区别
« 上一篇 2020年11月16日 上午12:00
vue生命周期钩子函数有哪些?
下一篇 » 2020年11月16日 上午12:00