ECMAScript的Call()與Apply()
2020/11/16 11:05:00 閱讀:2657
發(fā)布者:2657
ECMAScript的Call()與apply()兩個方法,call與apply的第一個參數(shù)都是需要調(diào)用的函數(shù)對象,在函數(shù)體內(nèi)這個參數(shù)就是this的值,剩余的參數(shù)是需要傳遞給函數(shù)的值。
call與apply都是用來改變this的指向,不同就是call傳的值可以是任意的,當(dāng)?shù)谝粋€參數(shù)為null、undefined的時候,默認(rèn)指向window;而apply傳的剩余值必須為數(shù)組。
例如: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調(diào)用sub方法
add.call(sub, args1,args2);即sub應(yīng)用add方法