04-React中绑定this并给函数传参的几种方式

    • 前言
    • 绑定 this 的方式一:bind()
    • 绑定 this 并给函数传参 的方式二:构造函数里设置 bind()
    • 绑定 this 并给函数传参 的方式三:箭头函数【荐】

前言

我们先来看下面这段代码:

components/MyComponent.jsx

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是 MyComponent 组件 默认的msg"};}render() {return (<div><h1>绑定This并传参</h1><input type="button" value="绑定this并传参" onClick={this.changeMsg} /><h3>{this.state.msg}</h3></div>);}changeMsg() {// 注意:这里的changeMsg()只是一个普通方法。因此,在触发的时候,这里的 this 是 undefinedconsole.log(this); // 打印结果:undefinedthis.setState({msg: "设置 msg 为新的值"});}
}

上面的代码中,点击按钮,执行 changeMsg() 方法,尝试修改 this.state.msg 的值。但是,这个方法执行的时候,是会报错的:

Uncaught TypeError: Cannot read property 'setState' of null

而且,打印this的结果也是 undefined。这是为啥呢?因为这里的 this 并不是指向 MyComponent 组件本身。

那如何让 changeMsg() 方法里面的 this,指向MyComponent 组件呢?办法总是有的,比如说,将changeMsg() 修改为箭头函数:

  changeMsg = () => {console.log(this); // 打印结果:MyComponent 组件this.setState({msg: "设置 msg 为新的值"});};

那么,除了箭头函数可以 绑定 this,还有没有其他的方式呢?我们接下来讲一讲。

绑定 this 的方式一:bind()

代码举例:

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是 MyComponent 组件 默认的msg"};}render() {return (<div><h1>绑定This并传参</h1>{/* bind 的作用:为前面的函数,修改函数内部的 this 指向。让 函数内部的this,指向 bind 参数列表中的 第一个参数 */}<inputtype="button"value="绑定this并传参"onClick={this.changeMsg1.bind(this)}/><h3>{this.state.msg}</h3></div>);}changeMsg1() {this.setState({msg: "设置 msg 为新的值"});}
}

上方代码中,我们为什么用 bind(),而不是用 call/apply 呢?因为 bind() 并不会立即调用,正是我们需要的。

注意:bind 中的第一个参数,是用来修改 this 指向的。第一个参数后面的所有参数,都将作为函数的参数传递进去。

我们来看看通过 bind() 是怎么传参的。

通过 bind() 绑定this,并给函数传参

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是 MyComponent 组件 默认的msg"};}render() {return (<div><h1>绑定This并传参</h1>{/* bind 的作用:为前面的函数,修改函数内部的 this 指向。让 函数内部的this,指向 bind 参数列表中的 第一个参数 */}<input type="button" value="绑定this并传参" onClick={this.changeMsg1.bind(this, "编程的一拳超人啊", "编程的一拳超人啊")} /><h3>{this.state.msg}</h3></div>);}changeMsg1(arg1, arg2) {this.setState({msg: "设置 msg 为新的值" + arg1 + arg2});}
}

绑定 this 并给函数传参 的方式二:构造函数里设置 bind()

我们知道,构造函数中的 this 本身就是指向组件的实例的,所以,我们可以在这里做一些事情。

代码举例:

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是 MyComponent 组件 默认的msg"};// 绑定 this 并给函数传参的方式2: 在构造函数中绑定并传参// 注意:当一个函数调用 bind 改变了this指向后,bind 函数调用的结果,有一个【返回值】,这个值,就是被改变this指向后的函数的引用。// 也就是说: bind 不会修改 原函数的 this 指向,而是改变了 “函数拷贝”的this指向。this.changeMsg2 = this.changeMsg2.bind(this, "编程的一拳超人恩", "编程的一拳超人恩");}render() {return (<div><h1>绑定This并传参</h1><input type="button" value="绑定this并传参" onClick={this.changeMsg2} /><h3>{this.state.msg}</h3></div>);}changeMsg2(arg1, arg2) {this.setState({msg: "设置 msg 为新的值" + arg1 + arg2});}
}

上方代码中,需要注意的是:当一个函数调用 bind 改变了this指向后,bind 函数调用的结果,有一个【返回值】,这个值,就是被改变this指向后的函数的引用。也就是说: bind 不会修改 原函数的 this 指向,而是改变了 “函数拷贝”的this指向。

绑定 this 并给函数传参 的方式三:箭头函数【荐】

第三种方式用得最多。

代码举例:

import React from "react";export default class MyComponent extends React.Component {constructor(props) {super(props);this.state = {msg: "这是 MyComponent 组件 默认的msg"};}render() {return (<div><h1>绑定This并传参</h1><inputtype="button"value="绑定this并传参"onClick={() => {this.changeMsg3("编程的一拳超人3", "编程的一拳超人3");}}/><h3>{this.state.msg}</h3></div>);}changeMsg3 = (arg1, arg2) => {// console.log(this);// 注意:这里的方式,是一个普通方法,因此,在触发的时候,这里的 this 是 undefinedthis.setState({msg: "绑定this并传参的方式3:" + arg1 + arg2});};
}

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

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

相关文章

Docker拉取不兼容的镜像解决办法

错误提示如下&#xff1a; WARNING: The requested images platform (linux/amd64) does not match the detected host platform (linux/arm64/v8) and no specific platform was requested295ef35cfefe0dce6904e017e89218695d9a9c092b45496218f4476357be4f9c 这个警告表明你…

android14 未充电状态电量低于15%弹框提示 10%直接关机

上层接收电量变化广播&#xff0c;添加未充电判断&#xff0c;做出弹框或关机动作 SystemUI\src\com\android\systemui\power\PowerUI.java Overridepublic void onReceive(Context context, Intent intent) {String action intent.getAction();if (PowerManager.ACTION_POWE…

ASP.NET Core 中 Kestrel 的应用及在前后端分离项目中的角色

目录 一、Kestrel 基础&#xff1a;轻量级且高性能的 Web 服务器 二、前后端分离项目架构&#xff1a;Vue、.NET Core API、Nginx 与 Kestrel 2.1 交互流程图 2.2 流程详解 三、Kestrel 在架构中的核心作用 四、launchSettings.json 与 Kestrel 配置的关系及底层机制 4.1…

Kotlin 退出循环总结

文章目录 Kotlin 退出循环总结for循环forEach()嵌套for循环lambda函数inline函数 Kotlin 退出循环总结 for循环 for ((index, value) in list.withIndex()) {if (value "c") {break // 退出循环}println("$index - $value") }// 0 - a // 1 - bfo…

再看C语言

目录 与Java的差异化 编程范式 跨平台 编译过程 包管理 基本类型 内存结构 重点掌握 进制、字节与计算 指针 结构体 关键词 动态内存 模块化 高级特性 动态链接 虚拟内存 打包编译 并发编程 现在需要参与到存储软件开发工作&#xff0c;存储层比较接近OS系统…

机器学习入门 | 训练、推理与其他机器学习活动(预处理、测试与评估)

在训练阶段&#xff0c;训练算法通过优化目标/损失函数在训练数据集上的表现&#xff0c;不断更新模型参数θ。在监督学习场景中&#xff0c;训练数据集由输入-标签对&#xff08;真实输出值&#xff09;组成。目标函数应当奖励模型根据训练输入成功预测真实输出的行为&#xf…

Node.js特训专栏-实战进阶:11. Redis缓存策略与应用场景

&#x1f525; 欢迎来到 Node.js 实战专栏&#xff01;在这里&#xff0c;每一行代码都是解锁高性能应用的钥匙&#xff0c;让我们一起开启 Node.js 的奇妙开发之旅&#xff01; Node.js 特训专栏主页 专栏内容规划详情 Redis 缓存策略与应用场景&#xff1a;从理论到实战的高…

【stm32】HAL库开发——Cube配置基本定时器

目录 一、Cube配置基本定时器 1.定时器CubeMX配置介绍 2.定时器中断控制LED 3.定时器常用函数 4.定时器从模式&#xff08;Reset Mode&#xff09; 5.定时器的从模式&#xff08;Gated Mode&#xff09; 6.定时器的编码器接口 一、Cube配置基本定时器 1.定时器CubeMX配置…

nginx反向代理后端服务restful及token处理

#user nobody; worker_processes 1;#error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info;#pid logs/nginx.pid;events {worker_connections 1024; } #代理mysql服务 stream {upstream mysql_backend {server 192.168…

正确理解Cola StateMachine不内置事务管理机制

✅ 正确理解&#xff1a;Cola StateMachine 并非“不支持”事务一致性&#xff0c;而是“不内置”事务管理机制 因为&#xff1a; Cola StateMachine 是轻量级、无状态、不依赖 Spring 的框架&#xff0c;它本身 不绑定任何事务上下文。它不像 Spring StateMachine 那样自动与…

AudioTrack使用

** AudioTrack ** AudioTrack 是 Android 音频系统中的核心类&#xff0c;用于播放原始音频数据&#xff08;PCM&#xff09;或压缩音频&#xff08;如 MP3、AAC&#xff09;。它提供了低级别的音频播放控制&#xff0c;适合需要精细管理的场景&#xff08;如游戏音效、实时音…

解密:MySQL 的常见存储引擎

在数据库领域&#xff0c;MySQL 作为一款广受欢迎的关系型数据库管理系统&#xff0c;提供了多种存储引擎以满足不同应用场景的需求。每种存储引擎都有其独特的特性、优势和适用场景。本文将深入探讨 MySQL 中几种常见的存储引擎&#xff0c;包括 InnoDB、MyISAM、MEMORY 和 AR…

qt和qtcreator版本关系

实例展示&#xff1a; 如图所示的qtcreator是使用qt5.15安装过程选择勾选了qtcreator 14.0.2&#xff0c;安装完成qtcreator版本信息&#xff1a; 安装过程中选择了这些构件kits&#xff0c;会自动识别到&#xff1a; 使用qt5.9.9另外安装的kits&#xff0c;需要手动设置才能识…

2个任务同时提交到YARN后2个都卡住(CDH)

文章目录 问题描述解决方案1、增加资源2、调整ApplicationMaster资源3、关闭YARN调度器的资源抢占4、不使用公平调度器 问题描述 在CDH集群上&#xff0c;同时提交2个任务到YARN后&#xff0c;2个任务都卡住 解决方案 1、增加资源 增加服务器的内存和CPU 2、调整Applicatio…

web3区块链-ETH以太坊

一. 以太坊概述 以太坊&#xff08;Ethereum&#xff09;作为区块链技术的代表性项目之一&#xff0c;自2015年发布以来&#xff0c;迅速成为全球区块链行业的核心基础设施。相比比特币&#xff0c;以太坊不仅支持点对点的价值转移&#xff0c;还引入了智能合约&#xff0c;使…

【智能协同云图库】智能协同云图库第二弹:用户管理系统后端设计与接口开发

用户管理系统 一、需求分析 对于用户模块&#xff0c;通常要具有下列功能&#xff1a; 二、方案设计 &#xff08;一&#xff09;库表设计 实现用户模块的难度不大&#xff0c;在方案设计阶段&#xff0c;我们需要确认以下内容&#xff1a; 库表设计用户登录流程如何对用户权限…

闲庭信步使用SV搭建图像测试平台:第十三课——谈谈SV的数据类型

&#xff08;本系列只需要modelsim即可完成数字图像的处理&#xff0c;每个工程都搭建了全自动化的仿真环境&#xff0c;只需要双击top_tb.bat文件就可以完成整个的仿真&#xff0c;大大降低了初学者的门槛&#xff01;&#xff01;&#xff01;&#xff01;如需要该系列的工程…

前端进阶之路-从传统前端到VUE-JS(第一期-VUE-JS环境配置)(Node-JS环境配置)(Node-JS/npm换源)

经过前面的传统前端开发学习后&#xff0c;我们接下来进行前端的VUE-JS框架学习&#xff08;写这篇文章的时候VUE-JS最新版是VUE3&#xff0c;所以默认为VUE3即可&#xff09; 首先&#xff0c;我们要配置Node-JS环境&#xff0c;虽然我们还不学习Node-JS但是Node-JS可以快速配…

Requests源码分析:面试考察角度梳理

简单描述执行流程 🌟 Q:能简单描述一下发送一个requests.get(url)请求时,在requests库内部的主要执行流程吗?(从调用get方法到收到响应) 入口委托: get() 方法内部调用 requests.request(GET, url)。Session 接管: request() 方法会获取或隐式创建一个 Session 对象,并…

航天VR赋能,无人机总测实验舱开启高效新篇​

(一)沉浸式培训体验​ 在传统的无人机培训中&#xff0c;操作人员主要通过理论学习和简单的模拟操作来掌握技能。但这种方式存在很大局限性&#xff0c;难以让操作人员真正感受无人机在复杂环境下的运行状态。而航天 VR 技术引入到 VR 无人机总测实验舱后&#xff0c;彻底改变了…