JS中 bind()的用法,call(),apply(),bind()异同点及使用,如何手写一个bind()

✨什么是bind()

bind()的MDN地址

bind() 方法创建一个新函数,当调用该新函数时,它会调用原始函数并将其 this 关键字设置为给定的值,同时,还可以传入一系列指定的参数,这些参数会插入到调用新函数时传入的参数的前面。

🍧 call(),apply(),bind()的异同

🎐 相同点

三者都是动态的修改函数内部的this指向

🎶 不同点

  • 传参方式不同,call()和bind()是按照顺序传参,apply()是通过数组/伪数组传参。
  • 执行机制不同,call()和apply()是立即执行函数,bind()不会立即执行函数,而是会返回一个修改过this的新函数。

🍿 call()

函数名.call(修改后的this,形参1,形参2…)

    person = {name: 'zhangsan'}function fn (a, b,) {console.log(this) //{name: 'zhangsan'}console.log(a, b) //1 2 console.log(a + b) //3}//call 立即执行函数 没有返回值let res = fn.call(person, 1, 2)console.log(res); //undefined

在这里插入图片描述

🎄apply()

函数名.apply(修改后的this,数组/伪数组)

    person = {name: 'zhangsan'}function fn (a, b) {console.log(this) //{name: 'zhangsan'}console.log(a, b) //1 2 console.log(a + b) //3}//apply 立即执行函数 没有返回值let res = fn.apply(person, [1, 2])console.log(res) //undefined

在这里插入图片描述

🎡 bind()

函数名.bind(修改后的this,形参1,形参2…)

  person = {name: 'zhangsan'}function fn (a, b, c, d) {console.log(this) //{name: 'zhangsan'}console.log(a, b, c, d) //1 2 3 4console.log(a + b + c + d) //10}//bind 不会立即执行函数,而是返回一个修改this的新函数let newFn = fn.bind(person, 1, 2)newFn(3, 4)

在这里插入图片描述

✨ 手写bind() :myBind()

可参照上一篇文章 手写call()

🎡代码

Function.prototype.myBind = function (thisArg, ...args) {return (...reArgs) => {// this:原函数(原函数.myBind)return this.call(thisArg, ...args, ...reArgs)}}// ------------- 测试代码 -------------const person = {name: 'zhangsan'}function func(numA, numB, numC, numD) {console.log(this)console.log(numA, numB, numC, numD)return numA + numB + numC + numD}const bindFunc = func.myBind(person, 1, 2)const res = bindFunc(3, 4)console.log('返回值:', res)

🎉 测试

在这里插入图片描述

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

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

相关文章

Map集合

Map中常见的API Map<键值对类型&#xff0c; 键值对对象类型> put&#xff08;K key , V value&#xff09;【可以有返回值】 添加/覆盖元素 在添加数据的时候&#xff0c;如果键不存在&#xff0c;那么直接将键对对象添加到map集合当中 在添加数据的时候&#xff0c…

云原生Kubernetes:pod基础

目录 一、理论 1.pod 2.pod容器分类 3.镜像拉取策略&#xff08;image PullPolicy&#xff09; 二、实验 1.Pod容器的分类 2.镜像拉取策略 三、问题 1.apiVersion 报错 2.pod v1版本资源未注册 3.取行显示指定pod信息 四、总结 一、理论 1.pod (1) 概念 Pod是ku…

jwt自定义表签发、jwt 多方式登录(auth的user表)

补充 # 1 接口文档编写规范&#xff1a;-1 描述-2 请求地址-3 请求方式-4 请求参数-headers-请求体-请求参数-5 请求编码格式-6 返回格式-示例-返回数据字段含义-其他&#xff1a;-错误状态码-...-接口文档编写位置-写在文件中&#xff1a;word&#xff0c;md&#xff0c;跟前…

centos定期清理磁盘

centos/linux定期清理磁盘 要定时清理空间&#xff0c;我们需要了解一个命令&#xff0c;find 命令&#xff0c;这个命令可以查询目录下特定文件名&#xff0c;生成日期的文件 小白教程&#xff0c;一看就会&#xff0c;一做就成。 1.查找需要删除的 find /data_back/zhhyba…

自动计算比例 计算属性 computed @input=“rate“

<el-col :span"12"><el-form-item label"当年累计实收租金:" prop"cumulativeRent"><el-inputv-model"createForm.cumulativeRent"input"rate"clearable:disabled"value 2"><template slot…

2023-9-11 拆分-Nim游戏

题目链接&#xff1a;拆分-Nim游戏 #include <iostream> #include <cstring> #include <algorithm> #include <unordered_set>using namespace std;const int N 110;int f[N];int sg(int x) {if(f[x] ! -1) return f[x];unordered_set<int> S;f…

【深度学习】 Python 和 NumPy 系列教程(八):Python类

目录 一、前言 二、实验环境 三、Python类&#xff08;Class&#xff09; 1、初始化方法&#xff08;__init__&#xff09; 2、属性和实例变量 3、方法和实例方法 4、继承 5、多态 6、类变量和静态方法 7、魔术方法 一、前言 Python是一种高级编程语言&#xff0c;由…

图片码二次渲染绕过

目录 一、环境 1、代码 2、文件处理方式 3、图片码的制作 二、绕过图片重构 1、可行性分析 2、数据比对 3、完成绕过 一、环境 以upload-labs靶场第十七关为例 1、代码 源码为&#xff1a; <?php include ../config.php; include ../head.php; include ../menu.…

Docker安装部署Nexus3作为内网镜像代理缓存容器镜像

Docker安装部署Nexus3作为内网镜像代理 一、背景描述 基础镜像比较小&#xff0c;仓库使用阿里云或者腾讯云拉取速度挺快&#xff0c;但是时光飞逝几年时间过去&#xff0c;再加上AI加持的情况下&#xff0c;有些镜像的大小已经接近20G&#xff01; 这种情况下不管是测试环境…

2024年java面试--mysql(2)

系列文章目录 2024年java面试&#xff08;一&#xff09;–spring篇2024年java面试&#xff08;二&#xff09;–spring篇2024年java面试&#xff08;三&#xff09;–spring篇2024年java面试&#xff08;四&#xff09;–spring篇2024年java面试–集合篇2024年java面试–redi…

网络传输方式

1. 单播 1.1. 定义 单播是指一种向单个目标地址传送数据的方式&#xff0c;即单独的一对一通讯方式。 1.2. 可使用协议 UDP、TCP等协议 1.3. 常见的场景 发送电子邮件传输文件 2. 广播 2.1. 定义 一种向本地网络中所有设备发送数据的方式。 2.2. 常见的场景 电视和电…

AAOS音频路由 问题分析

文章目录 问题描述问题分析流程梳理问题原因 问题描述 多屏设备&#xff0c;没有按照配置car_audio_configuration.xml配置输出。也即是每个屏幕播放的音频没有对应输出到想对应的bus设备。 问题分析 首先根据hal层的log&#xff0c;确认框架层配置的bus&#xff0c;确认框架…

Swift学习笔记四(function 篇)

目录 1 Function 概念及定义。 1.1 Function概念 1.2 Function定义 1.3 Function参数 1.3.1 无形式参数 1.3.2 多形式参数的函数 1.4 返回值 1.4.1 无返回值类型 1.4.2 多返回值类型 1.4.3 可选元组返回类型 1.4.4 隐式返回的类型 1.4.5 实参标签和形参名 1.4.6 指…

卷积神经网络:深度学习的重要支柱

卷积神经网络&#xff1a;深度学习的重要支柱 卷积神经网络&#xff08;Convolutional Neural Network&#xff0c;简称CNN&#xff09;是深度学习领域中最著名的算法之一。它是一种特殊的神经网络&#xff0c;尤其适用于处理图像、视频等网格形式的数据。自从1998年Yann LeCun…

功率放大器的定义详解

功率放大器是一种电子放大器&#xff0c;主要用于将输入信号的功率放大到足以驱动负载或输出器件所需的水平。通常&#xff0c;功率放大器会将低电平高电流的输入信号转换成高电平低电流的输出信号&#xff0c;以便给负载提供足够的功率。 功率放大器广泛应用于各种应用场合&am…

Linux工具——gcc

目录 一&#xff0c;gcc简介 二&#xff0c;C语言源文件的编译过程 1.预处理 2.编译 3.汇编 4.链接 5.动静态库 一&#xff0c;gcc简介 相信有不少的小白和我一样在学习Linux之前只听说过visual studio。其实这个gcc这个编译器实现的功能便是和visual studio一样的功能&…

学习 [Spring MVC] 的JSR 303和拦截器,提高开发效率

&#x1f3ac; 艳艳耶✌️&#xff1a;个人主页 &#x1f525; 个人专栏 &#xff1a;《推荐】Spring与Mybatis集成整合》 ⛺️ 生活的理想&#xff0c;不断更新自己 ! 1.JSR303 1.1JSR303是什么 JSR 303是Java规范请求&#xff08;Java Specification Request&#xff09;…

matlab数据处理: cell table array+datetime

原数据文件.csv matlab xlsread(filename{i},B2:T2881) 会同于Excel最多1048576行 舍弃 a{1,i} xlsread(filename{i},‘B2:T2881’);%读取excel文件,选定区域’B2:G2881’ readcell(filename{i},Range,E2:M2881) 会全部读取 优选 对于日期 yyyy-MM-dd HH:mm:ss.000 matlab cel…

在Ubuntu上建立博客网站,利用Cpolar+Inis快速实现专业写作

文章目录 前言1. Inis博客网站搭建1.1. Inis博客网站下载和安装1.2 Inis博客网站测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2 Cpolar稳定隧道&#xff08;云端设置&#xff09;2.3.Cpolar稳定隧道&#xff08;本地设置&#xff09; 3. 公网访问测试总…

设计模式-模板方法

文章目录 前言模板方法模式简介Java代码示例模板方法使用场景模板方法使用场景 前言 当我们需要在一个算法的框架中定义算法的骨架&#xff0c;并将一些步骤的具体实现留给子类来完成时&#xff0c;模板方法模式是一种非常有用的设计模式。这篇博客将介绍模板方法模式的概念&a…