Javascript 方法apply和call的差别

Posted clnchanpin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Javascript 方法apply和call的差别相关的知识,希望对你有一定的参考价值。

call与aplly都属于Function.prototype的一个方法,所以每一个function实例都有call、apply属性

同样点:
call()方法和apply()方法的作用同样:

改变原调用函数的内部this指向。

call()方法和apply()方法的第一个參数都是调用call/apply方法的函数内部this的指向。

不同点:
当调用call/apply方法的函数有參数时,call/apply方法也须要传參

call的2參、3參...n參分别表示原函数的1參、2參...n-1參

apply的2參是一个数组,数组元素按顺序存储原方法的1參、2參...n參

举例:

function add(c, d){ 
/*
    这里的this表示add.call/apply的一參
    假设直接调用add(c,d),那么this指向window
*/
return this.a + this.b + c + d; 
} 
var o = {a:1, b:3}; 
add.call(o, 5, 7); // 1 + 3 + 5 + 7 = 16 
add.apply(o, [10, 20]); // 1 + 3 + 10 + 20 = 34 



以上是关于Javascript 方法apply和call的差别的主要内容,如果未能解决你的问题,请参考以下文章

Javascript中call和apply的区别与详解

Javascript apply()和call()方法

详解 JavaScript的 call() 和 apply()

Javascript之模拟实现call,apply

关于javascript中call()和apply()方法的总结

javascript中apply()和call()方法及区别