JavaScript中apply与call用法解析

版权申诉
0 下载量 71 浏览量 更新于2024-08-18 收藏 16KB DOCX 举报
"JavaScript中`apply`与`call`的简单用法详解" 在JavaScript中,`apply`和`call`都是用于改变函数调用时的上下文(即`this`关键字指向的对象)的重要方法。它们属于`Function.prototype`,因此每一个函数实例都可以使用这两个方法。虽然它们的目的相似,但使用方式有所不同。 ### `call` 方法 `call`方法允许我们将一个函数直接应用于指定的对象,并可以传入一系列参数。语法如下: ```javascript functionName.call(thisArg, arg1, arg2, ..., argN); ``` - `thisArg`:在函数内部,`this`将被设置为`thisArg`。 - `arg1, arg2, ..., argN`:函数调用时传递的参数列表。 例如: ```javascript function A() { this.getName = function(xx) { return xx; }; } function B() {} var a = new A(); console.log(a.getName('iamA')); // 输出:'iamA' var b = new B(); console.log(a.getName.call(b, 'iamB')); // 输出:'iamB' ``` 在这个例子中,`getName`方法原本属于`A`的实例`a`,但通过`call`,我们可以使`B`的实例`b`调用`getName`,并传入参数`'iamB'`,结果依然正确地返回`'iamB'`。 ### `apply` 方法 `apply`与`call`类似,也是改变`this`的指向,但其参数传递方式不同。`apply`接受两个参数: ```javascript functionName.apply(thisArg, [argsArray]); ``` - `thisArg`:同`call`方法中的`thisArg`。 - `argsArray`:一个数组或者类数组对象,其元素会被作为单独的参数传递给函数。 例如: ```javascript function A() { this.sum = function(a, b) { return a + b; }; } function B() {} var a = new A(); console.log(a.sum(1, 2)); // 输出:3 var b = new B(); console.log(a.sum.apply(b, [2, 2])); // 输出:4 ``` 这里,`sum`方法通过`apply`被`b`调用,`[2, 2]`数组中的元素被分别作为参数传递,结果是`4`。 ### 应用场景 `call`和`apply`在处理数组或类数组对象时非常有用,尤其是在需要使用数组方法但实际对象不是数组的情况下。例如,`document.getElementsByTagName("*")`返回的是一个类似数组的对象,它不支持`Array`对象的方法,如`push`、`pop`等。这时,我们可以使用`Array.prototype.slice.call()`将它转换为真正的数组: ```javascript var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*")); ``` 现在,`domNodes`就可以使用所有数组方法了。 `call`和`apply`是JavaScript中非常实用的功能,它们提供了灵活的上下文切换和参数传递方式,使得代码更加通用和可复用。理解并熟练运用这两个方法,能提升你在JavaScript开发中的技能水平。