• 24小时服务热线:400-088-1128

当前位置 南顺网络>> 知识拓展

js中的call()、apply

apply/call 调用: 我们知道,在 js 里,函数其实也是一个对象,那么函数自然也可以拥有它自己的方法,有点绕,就好像函数可以自己有属性也是一个函数。其中每个函数都拥有 apply() 这个方法,让我们构造一个参数数组传递给函数,同时可以自己来设置 this 的值,这就是它最强大的地方。apply 接收2个参数,第一个是将传递给这个函数的 this 的值,第二个是参数数组。看代码:

function a(xx) {

    this.b = xx;

}

var o = {};

a.apply(o, [5]);

alert(a.b);    // undefined

alert(o.b);    // 5

是不是很神奇,函数 a 居然可以给 o 加属性值。当然,如果你 apply 的第一个参数传递 null,那么在函数 a 里面 this 指针依然会绑定全局对象。你可能要问了,apply 函数是哪来的,因为在 js 里所有的函数都有一个共同的 prototype,也就是传说中的 Function.prototype, 这个原型里有两个神奇的方法,一个就是这里的 apply ,另一个就是让题主疑惑的 call。


call() 方法和 apply() 方法很类似,它们的存在都是为了改变 this 的绑定,那 call() 和 apply() 有什么区别呢?就我个人看来,没啥鸟区别。。。开玩笑!刚刚说了,上面 apply() 接收两个参数,第一个是你想要 this 绑定的对象,第二个是一个参数数组,注意是一个数组,你想传递给这个函数的所有内容都放在数组里,然后 apply() 函数会在传递形参时自动帮你展开,同时加入我上面提到的另一个神奇形参 arguments。而 call() 呢,它的第一个参数也是你想要 this 绑定的对象,但是后面可以接受不定参数,而不再是一个数组,也就是你可以像平时给函数传参那样把这些参数一个一个传递,当然,神奇形参 arguments 还是不会少的。所以如果一定要说有什么区别的话,看起来是这样的:

function a(xx, yy) {

    alert(xx, yy);

    alert(this);

    alert(arguments);

}

a.apply(null, [5, 55]);

a.call(null, 5, 55);