编辑:这个问题是由于我的误解而提出的。请谨慎行事,因为阅读它可能会浪费您的时间。
我想call
and apply
将执行给定一组参数的函数,但我得到的测试结果令人困惑。看我的测试代码:
window.z = 0;
(function(){++(window.z)}).call(this, 1, 2, 3)
我希望z
执行后为3。然而,z 为 1。
(function(){++(window.z)}).apply(this, [1, 2, 3])
同样在这里。z == 1;
我也尝试简单地记录输入参数:
var x = function(y){console.log(y);}
x.call(this, 1, 2, 3);
结果?仅记录 1 个。
我在这里做错了什么?
(在 Chrome 和 Firefox 中使用 Firebug 进行测试。)
Both call https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Function/call and apply https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Function/apply仅调用该函数一次。不同之处在于调用参数的传递方式。
对于调用,上下文(第一个参数)之后的每个参数都是一个参数。使用 apply 时,第二个参数应该是一个数组like参数对象(第一个参数仍然提供上下文)。
function foo(a, b, c) {
};
foo.call(this, 1, 2, 3); // a == 1, b == 2, c == 3;
foo.apply(this, [1,2,3]); // a == 1, b == 2, c == 3;
如果您想多次调用该函数,只需将调用放入循环即可完成此操作。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)