首页 > 代码库 > JS中apply()与call()的含义与区别

JS中apply()与call()的含义与区别

JavaScript中,apply()与call()的含义一样,均为改变调用函数中的this指向。
其中apply()与call()的第一个参数表示所要指向的对象,若调用函数无参数可不写,则默认为window。
第一个参数后的参数表示调用函数的参数,其中apply()第一个参数后面的参数为一个数组,call()第一个参数后面为0或多个参数。

例:

 1 window.x = 100; 2  3  4 var obj = {}; 5 obj.x = 1; 6 obj.test = function(a) { 7     alert(this.x + 20 + a); 8 } 9 10 11 var abc = {};12 abc.x = 2;13 abc.test = function() {14     alert(this.x + 30 + a);15 }16 17 18 obj.test(10);                 // 结果为31,this指向obj19 obj.test.call(window, 10);         // 结果为130,this指向window20 obj.test.call(abc, 10);         // 结果为32,this指向abc21 22 23 obj.test.apply(window, [10]);    // 结果为130,this指向window24 obj.test.apply(abc, [10])        // 结果为32,this指向abc