JavaScript中call()与apply()的作用与区别?

简介: JavaScript中call()与apply()的作用与区别?


JavaScript中的call()apply()是两个常用的方法,它们用于在调用函数时指定函数内部的this值,并且还可以传入参数。这两个方法有着相似的作用,但也有一些区别。本文将详细介绍它们的作用与区别,并提供相关代码示例。

开头

在JavaScript中,call()apply()都是用于在特定的作用域中调用函数。它们的作用是改变函数体内this的指向,并且可以传入参数。接下来我们将分别介绍它们的具体作用以及区别,并通过代码示例进行说明。

call()与apply()的优缺点

call()和apply()都是用于调用函数的方法,它们各自有一些优缺点。

call()的优点:

  1. 可以直接传递参数列表,使代码更加简洁和直观。
  2. 可以更容易地重用现有的函数,只需传递不同的参数列表即可。

call()的缺点:

  1. 当参数数量较多时,需要手动逐个传递,可能会显得冗长。
  2. 不太适合在参数为数组的情况下使用,需要手动展开数组。

apply()的优点:

  1. 接受参数数组作为参数,适合在参数为数组的情况下使用,可以更方便地传递参数。
  2. 可以动态地传递参数,适用于参数数量不确定的情况。

apply()的缺点:

  1. 传递参数时需要手动封装成数组,可能会显得不够直观。
  2. 在参数为单个值的情况下,使用apply()可能会显得多余。

总的来说,call()和apply()各有其适用的场景,选择使用哪种方法取决于具体的需求和代码结构。

call()的作用与用法

call()方法允许您在调用函数时,将一个对象绑定到this,并且可以传入多个参数。这样就可以在调用函数时指定函数内部的this值,并且传入相应的参数。下面是一个简单的示例:

function greet(name) {
  return "Hello, " + name;
}
console.log(greet.call(null, "Alice"));

在上面的示例中,我们使用call()方法将null绑定到this,并传入参数"Alice"。这样在调用greet函数时,函数内部的this会指向null,并且会输出"Hello, Alice"。

apply()的作用与用法

apply()方法与call()类似,它也可以改变函数体内this的指向,并且可以传入参数。不同的是,apply()接受的参数是以数组的形式传入的。下面是一个示例:

function sum(a, b) {
  return a + b;
}
console.log(sum.apply(null, [3, 5]));

在上面的示例中,我们使用apply()方法将null绑定到this,并传入参数[3, 5]。这样在调用sum函数时,函数内部的this会指向null,并且会输出8。

代码示例

var name = "Evan";
  var age = 20;
  var person = {
    name: "Hillary",
    age: 19,
    sayIntroduce: function () {
      return (
        "Hello, My name is " + this.name +" and I'm " +this.age +" years old."
      );
    },
    sayHobby: function (val1, val2) {
        return "I'm " + this.name + ", I like " + val1 + " and " + val2 + ".";
    }
  };
  
  var person1 = {
    name: "Coy",
  };
  
  console.log(person.sayIntroduce()); 
  // Hello, My name is Hillary and I'm 19 years old.
  
  // 当我们通过 call 和 apply 来this的指向时,不传任何参数,则默认为将this指向修改为 windows
  console.log(person.sayIntroduce.call()); 
  // Hello, My name is Evan and I'm 20 years old.
  console.log(person.sayIntroduce.apply()); 
  // Hello, My name is Evan and I'm 20 years old.
  
  // 有参数时,this 指向第一个参数:将this指向 person1,由于person1中没有age属性,因此为 undefined
  console.log(person.sayIntroduce.call(person1)); 
  // Hello, My name is Coy and I'm undefined years old.
  console.log(person.sayIntroduce.apply(person1)); 
  // Hello, My name is Coy and I'm undefined years old.
  
  // 当需要传递参数时,call可以直接写多个参数,apply需要用数组方式传递:
  console.log(person.sayHobby.call(person1, 'swimming', 'hiking')); 
  // I'm Coy, I like swimming and hiking. 
  console.log(person.sayHobby.apply(person1, ['swimming', 'hiking'])); 
  // I'm Coy, I like swimming and hiking. 

区别与总结

call()和apply()都是用来调用函数的方法,它们的作用是改变函数执行时的上下文(即this指向)和传递参数。

call()方法接收函数的上下文和参数列表作为参数,而apply()方法接收函数的上下文和一个参数数组作为参数。

call()和apply()的主要区别在于参数的传递方式,call()需要将参数逐个传入,而apply()可以接收一个参数数组。

他们的区别在于接收参数的方式不同: call():第一个参数是this值没有变化,变化的是其余参数都直接传递给函数。在使用call()方法时,传递给函数的参数必须逐个列举出来。 apply():传递给函数的是参数数组

总之,call()apply()是非常有用的方法,它们可以在调用函数时灵活地指定this的指向,并且传入相应的参数。在实际开发中,根据具体的需求选择使用call()apply()可以帮助我们更好地编写出清晰、灵活的代码。


目录
相关文章
|
28天前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
26 1
|
1月前
|
设计模式 JavaScript 前端开发
js中new和object.creat区别
【10月更文挑战第29天】`new` 关键字和 `Object.create()` 方法在创建对象的方式、原型链继承、属性初始化以及适用场景等方面都存在差异。在实际开发中,需要根据具体的需求和设计模式来选择合适的方法来创建对象。
|
2月前
|
JavaScript 前端开发
JS高级—call(),apply(),bind()
【10月更文挑战第17天】call()`、`apply()`和`bind()`是 JavaScript 中非常重要的工具,它们为我们提供了灵活控制函数执行和`this`指向的能力。通过合理运用这些方法,可以实现更复杂的编程逻辑和功能,提升代码的质量和可维护性。你在实际开发中可以根据具体需求,选择合适的方法来满足业务需求,并不断探索它们的更多应用场景。
14 1
|
2月前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
108 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
28天前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
25 1
JavaScript中的原型 保姆级文章一文搞懂
|
5月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
103 2
|
24天前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
17 0
|
5月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
146 4