改变函数调用上下文:apply与call方法详解及实例

目录

改变函数调用上下文:apply与call方法详解及实例

一、什么是 apply 方法?

1、apply 语法

2、apply 示例

二、什么是 call 方法?

1、call 语法

 2、call 示例

三、apply 和 call 的共同与差异

1、apply 和 call 的共同点

2、apply 和 call 的差异

四、apply 和 call 的其他实用技巧

1、使用 apply 扩展 Math 对象的功能

 2、借用数组方法

3、模拟类继承

五、总结


作者:watermelo37

涉及领域:Vue、SpingBoot、Docker、LLM、python等

---------------------------------------------------------------------

温柔地对待温柔的人,包容的三观就是最大的温柔。

---------------------------------------------------------------------

bfa6b42ca25842e791c1fcb3bafe61af.jpeg

改变函数调用上下文:apply与call方法详解及实例

a73f6b325cec42d7b6c2a101481df93f.jpeg

        JavaScript 提供了很多方法来增强函数的灵活性,其中 apply 和 call 是两个重要的函数方法。了解它们的使用场景和区别可以帮助我们更好地管理上下文(this)并提升代码的可读性。

一、什么是 apply 方法?

        apply 方法是 JavaScript 函数对象的一个方法,它允许你在调用函数时,显式地指定函数内部的 this 值,并传入一个包含参数的数组或类数组对象。

1、apply 语法

func.apply(thisArg, [argsArray])

  • thisArg:调用函数时 this 指向的对象。
  • argsArray:一个数组或类数组对象,用于指定函数调用时的参数列表。

2、apply 示例

        假设我们有一个函数 calculateArea,用于计算矩形的面积:

function calculateArea(length, width) {return length * width;
}const dimensions = [10, 5];
const area = calculateArea.apply(null, dimensions);
console.log(area); // 输出:50

        在这个例子中,apply 方法允许我们将数组 dimensions 作为参数传递给 calculateArea 函数。

二、什么是 call 方法?

        与 apply 类似,call 方法也是一个 JavaScript 函数对象的内置方法。它允许我们在调用函数时指定 this 值,但不同的是,call 方法的参数是直接传递的,而不是作为数组。

1、call 语法

func.call(thisArg, arg1, arg2, ...)

  • thisArg:调用函数时 this 指向的对象。
  • arg1, arg2, ...:要传递给函数的参数。

 2、call 示例

        用同样的 calculateArea 函数,我们可以通过 call 方法直接传递参数:

const area2 = calculateArea.call(null, 10, 5);
console.log(area2); // 输出:50

        在这个例子中,call 方法通过逐个传递参数的方式调用了 calculateArea。

三、apply 和 call 的共同与差异

1、apply 和 call 的共同点

        apply 和 call 方法都可以显式地设置 this,并立即调用函数。这使得它们非常适用于以下场景:

  • 显式绑定 this:将函数借用到其他对象上,避免重新定义类似的函数。
  • 动态调用函数:根据不同的参数或上下文来灵活调用函数。

2、apply 和 call 的差异

  • 参数传递方式不同:这是 apply 和 call 之间的主要区别。
    •  apply 接收一个数组或类数组对象,将其中的值作为参数传递给函数。
    •  call 逐个接受参数,这些参数必须按顺序传递。
  • 适用场景不同
    • 当参数已经在数组或类数组对象中时,apply 更加方便。
    • 当参数数量和顺序明确时, call 方法更直接。

        再举个对比的例子:

// 使用 apply 方法
function introduce(name, age) {console.log(`My name is ${name} and I am ${age} years old.`);
}const personInfo = ["Alice", 25];
introduce.apply(null, personInfo); // 使用 apply 传递数组参数
//My name is Alice and I am 25 years old.// 使用 call 方法
introduce.call(null, "Bob", 30); // 使用 call 直接传递参数
//My name is Bob and I am 30 years old.

        在上述例子中,apply 使用数组传递参数,而 call 方法直接传递了两个参数。

四、apply 和 call 的其他实用技巧

1、使用 apply 扩展 Math 对象的功能

        通过 apply 方法,可以轻松地将数组传递给 Math.max 或 Math.min 函数,求出数组的最大或最小值

const numbers = [5, 6, 2, 3, 7];
const max = Math.max.apply(null, numbers);
console.log(max); // 输出:7const min = Math.min.apply(null, numbers);
console.log(min); // 输出:2

Tips:在 apply 与 call 方法中,null的作用,是将this指向变成null,还是代表没有传入新的this指向,原指向不变呢?

        答:null 只是占位符,并不影响 this 的实际指向。

 2、借用数组方法

        因为 arguments 对象是类数组的,我们可以借用数组方法将其转化为真正的数组。例如,使用 Array.prototype.slice.call 方法将 arguments 转化为数组:

function listArgs() {const args = Array.prototype.slice.call(arguments);console.log(args);
}listArgs(1, 2, 3, 4); // 输出:[1, 2, 3, 4]

3、模拟类继承

        可以使用 call 来将父类的构造函数借用到子类上,从而实现继承。以下是一个简单的示例:

function Person(name) {this.name = name;
}function Student(name, age) {Person.call(this, name); // 使用 call 将 Person 的构造函数借用到 Student 中this.age = age;
}const student1 = new Student("Tom", 20);
console.log(student1.name); // 输出:Tom
console.log(student1.age);  // 输出:20

五、总结

        apply 和 call 是 JavaScript 中两个重要的函数方法,它们允许我们在调用函数时显式地设置 this,并传递参数。它们的区别在于参数传递方式:apply 使用数组,而 call 则是直接传递参数。在实际开发中,这两个方法经常用于显式绑定 this、借用方法、动态函数调用等场景。掌握它们可以提升代码的灵活性和可读性。

        只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

        其他热门文章,请关注:

        你真的会使用Vue3的onMounted钩子函数吗?Vue3中onMounted的用法详解

        通过array.filter()实现数组的数据筛选、数据清洗和链式调用

        极致的灵活度满足工程美学:用Vue Flow绘制一个完美流程图

        el-table实现动态数据的实时排序,一篇文章讲清楚elementui的表格排序功能

        在线编程实现!如何在Java后端通过DockerClient操作Docker生成python环境

        干货含源码!如何用Java后端操作Docker(命令行篇)

        JavaScript中闭包详解+举例,闭包的各种实践场景:高级技巧与实用指南

        Dockerfile全面指南:从基础到进阶,掌握容器化构建的核心工具

        MutationObserver详解+案例——深入理解 JavaScript 中的 MutationObserver

        TreeSize:免费的磁盘清理与管理神器,解决C盘爆满的燃眉之急

        Idea启动SpringBoot程序报错:Port 8082 was already in use;端口冲突的原理与解决方案

        PDF预览:利用vue3-pdf-app实现前端PDF在线展示

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/453508.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

centos7-网络模式选择NAT连接时遇到的问题

今天花了我一上午的时间,必须要记录一下。 新创建的虚拟机,选择的centos7-NAT的网路连接模式。 科普一下: 我选择的NAT模式, 然后改了 vi /etc/sysconfig/network-scripts/ifcfg-ens33文件的 source ~/.bashrc和reboot之后 执行service n…

nginx 快速入门

配置文件 nginx.conf 每个 http 块可以包括多个 server 块,而每个 server 块就相当于一个虚拟主机 #这一行表示这个server块监听的端口是80,只要有请求访问了80端口,此server块就处理请求listen 80;# 表示这个server块代表的虚拟主机的名字…

优雅的入参校验,Valid常用校验

更好的阅读体验:优雅的入参校验,Valid常用校验 对于前端传递的参数,正常情况下后端是要进行一些必要的校验,最简单的做法是用 if 效果是可以,但不优雅。使用 Validator 代替 if,就会优雅很多 ps&#xff…

重学SpringBoot3-Spring Data JPA简介

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-Spring Data JPA简介 1. 什么是 Spring Data JPA?2. Spring Data JPA 的核心概念2.1. 实体(Entity)2.2. Repository&…

SpringBoot整合mybatisPlus实现批量插入并获取ID

背景:需要实现批量插入并且得到插入后的ID。 使用for循环进行insert这里就不说了,在海量数据下其性能是最慢的。数据量小的情况下,没什么区别。 【1】saveBatch(一万条数据总耗时:2478ms) mybatisplus扩展包提供的:…

吴恩达深度学习(9)

经典的神经网络: 残差网络(ResNet) 太深的神经网络容易出现梯度消失与梯度爆炸等问题。 跳跃连接,能从一层中得到激活并将其传递给下一层,甚至更深的网络层。利用这个可以训练网络层很深很深的残差网络(R…

Go 1.19.4 命令调用、日志、包管理、反射-Day 17

1. 系统命令调用 所谓的命令调用,就是通过os,找到系统中编译好的可执行文件,然后加载到内存中,变成进程。 1.1 exec.LookPath(寻找命令) 作用: exec.LookPath 函数用于在系统的环境变量中搜索可…

海思hi3536c配置内核支持USB摄像头

linux内核版本:linux-3.18.20 配置步骤 进入Device Drivers 选择Multimedia support,并进入 选择Media USB Adapters,并进入 如下图,选择这几项: 保存退出,重新编译内核下载 内核更新后&#xff0c…

DIFFEDIT: DIFFUSION-BASED SEMANTIC IMAGE EDIT- ING WITH MASK GUIDANCE

https://arxiv.org/pdf/2210.11427 问题引入 针对的问题是输入text prompt完成对图片的编辑,基于的是T2I model;本文的方法不需要额外提供mask来将任务变为inpaint任务,而是可以自动的根据text prompt来提取出需要编辑区域的mask methods

支付域——支付背景

摘要 支付体系作为现代金融的重要组成部分,承担着资金流转与经济交易的关键职能。随着科技的发展,全球支付方式迅速演变,尤其是在中国,移动支付、互联网支付等新兴方式已广泛应用。传统的现金、银行卡支付逐渐被数字支付所取代,支付宝、微信支付等第三方支付机构成为主流…

计算机网络:数据链路层 —— 扩展共享式以太网

文章目录 共享式以太网共享式以太网存在的问题在物理层扩展以太网扩展站点与集线器之间的距离扩展共享式以太网的覆盖范围和站点数量 在链路层扩展以太网网桥的主要结构网桥的基本工作原理透明网桥自学习和转发帧生成树协议STP 共享式以太网 共享式以太网是当今局域网中广泛采…

Leetcode|24. 两两交换链表中的节点 ● 19.删除链表的倒数第N个节点 ● 面试题 02.07. 链表相交 ● 142.环形链表II

24. 注意:涉及头节点的修改或者删除时,最好设置一个虚拟的头结点,方便简化代码,不必进行是否为头节点的的判断,简化code class Solution { public:ListNode* swapPairs(ListNode* head) {ListNode* dummyHead new Li…

Adobe Acrobat DC 打印PDF文件,没有打印出注释的解决方法

adobe acrobat在打印的时候,打印不出来注释内容(之前一直可以,突然就不行),升级版本、嵌入字体等等都试过,也在Google找了半天和问了GPT也么找着办法。 无奈之下,自己通过印前检查,…

ASP.NET Core8.0学习笔记(二十一)——EFCore关系配置API

一、关系配置API概述 当我们需要指定一个字段作为外键,而这个外键又不符合以上四种约定时,就需要在IEntityTypeConfiguration实现类(对应的配置类)中使用Fluent API直接配置外键。理论上可以通过API直接指定一个属性,…

HTTP快速入门

HTTP报文结构 HTTP 协议主要由三大部分组成: ● 起始行(start line):描述请求或响应的基本信息; ● 头部字段(header):使用 key-value 形式更详细地说明报文; ● 消息正…

vue 页面导出gif图片 img 导出gif 超简单~

1.首先需要新建一个文件件 新建gif文件夹。这两个文件在文章最后面需要可自提 2.出gif分为两种情况 第一种情况 页面是img标签,直接导出图片作为gif 第二种情况 页面是div标签,需要导出div里面的图片作为gif 2.1页面是img标签,直接导出图…

[论文阅读]Distilling ChatGPT for Explainable Automated Student Answer Assessment

Distilling ChatGPT for Explainable Automated Student Answer Assessment http://arxiv.org/abs/2305.12962 简要概述 文章的背景是 教育领域的学生答题评估,传统的评估需要高成本的人工,随着CHATGPT的发展,研究人员发现这种能够有效处理…

嵌入式QT中基本工程模板分析

大家好,今天主要来分享一下,如何分析一下QT的工程代码文件。 第一:QT工程分析

CentOS安装NVIDIA驱动、CUDA以及nvidia-container-toolkit

0.提前准备 0.1.更新yum源(以阿里为例) 0.1.1 备份当前的yum源 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 0.1.2 下载新的CentOS-Base.repo 到/etc/yum.repos.d/ CentOS 5 wget -O /etc/yum.repos.d/CentOS-Base…

Xilinx UltraScale系列FPGA纯verilog图像缩放,工程项目解决方案,提供2套工程源码和技术支持

目录 1、前言工程概述免责声明FPGA高端图像处理培训 2、相关方案推荐我这里已有的FPGA图像缩放方案本方案在Xilinx Artix7 系列FPGA上的应用本方案在Xilinx Kintex7 系列FPGA上的应用本方案在Xilinx Zynq7000 系列FPGA上的应用本方案在国产FPGA紫光同创系列上的应用本方案在国产…