当前位置: 首页 > news >正文

HoRain云--React 事件处理

🎬 HoRain云小助手:个人主页

🔥 个人专栏: 《Linux 系列教程》《c语言教程》

⛺️生活的理想,就是为了理想的生活!


⛳️ 推荐

前些天发现了一个超棒的服务器购买网站,性价比超高,大内存超划算!忍不住分享一下给大家。点击跳转到网站。

专栏介绍

专栏名称

专栏介绍

《C语言》

本专栏主要撰写C干货内容和编程技巧,让大家从底层了解C,把更多的知识由抽象到简单通俗易懂。

《网络协议》

本专栏主要是注重从底层来给大家一步步剖析网络协议的奥秘,一起解密网络协议在运行中协议的基本运行机制!

《docker容器精解篇》

全面深入解析 docker 容器,从基础到进阶,涵盖原理、操作、实践案例,助您精通 docker。

《linux系列》

本专栏主要撰写Linux干货内容,从基础到进阶,知识由抽象到简单通俗易懂,帮你从新手小白到扫地僧。

《python 系列》

本专栏着重撰写Python相关的干货内容与编程技巧,助力大家从底层去认识Python,将更多复杂的知识由抽象转化为简单易懂的内容。

《试题库》

本专栏主要是发布一些考试和练习题库(涵盖软考、HCIE、HRCE、CCNA等)

目录

⛳️ 推荐

专栏介绍

实例

向事件处理程序传递参数


React 元素的事件处理和 DOM 元素类似。但是有一点语法上的不同:

HTML 通常写法是:

<button onclick="activateLasers()"> 激活按钮 </button>

React 中写法为:

<button onClick={activateLasers}> 激活按钮 </button>

在 React 中另一个不同是你不能使用返回false的方式阻止默认行为, 你必须明确使用 preventDefault。

例如,通常我们在 HTML 中阻止链接默认打开一个新页面,可以这样写:

<a href="#" onclick="console.log('点击链接'); return false"> 点我 </a>

在 React 的写法为:

function ActionLink() { function handleClick(e) { e.preventDefault(); console.log('链接被点击'); } return ( <a href="#" onClick={handleClick}> 点我 </a> ); }

实例中 e 是一个合成事件。

使用 React 的时候通常你不需要使用 addEventListener 为一个已创建的 DOM 元素添加监听器。你仅仅需要在这个元素初始渲染的时候提供一个监听器。

当你使用 ES6 class 语法来定义一个组件的时候,事件处理器会成为类的一个方法。例如,下面的 Toggle 组件渲染一个让用户切换开关状态的按钮:

实例

class Toggle extends React.Component { constructor(props) { super(props); this.state = {isToggleOn: true}; // 这边绑定是必要的,这样 `this` 才能在回调函数中使用 this.handleClick = this.handleClick.bind(this); } handleClick() { this.setState(prevState => ({ isToggleOn: !prevState.isToggleOn })); } render() { return ( <button onClick={this.handleClick}> {this.state.isToggleOn ? 'ON' : 'OFF'} </button> ); } } const root = ReactDOM.createRoot(document.getElementById("root")); root.render( <Toggle />, document.getElementById('example') );

你必须谨慎对待 JSX 回调函数中的 this,类的方法默认是不会绑定 this 的。如果你忘记绑定 this.handleClick 并把它传入 onClick, 当你调用这个函数的时候 this 的值会是 undefined。

这并不是 React 的特殊行为;它是函数如何在 JavaScript 中运行的一部分。通常情况下,如果你没有在方法后面添加 () ,例如 onClick={this.handleClick},你应该为这个方法绑定 this。

如果使用 bind 让你很烦,这里有两种方式可以解决。如果你正在使用实验性的属性初始化器语法,你可以使用属性初始化器来正确的绑定回调函数:

class LoggingButton extends React.Component { // 这个语法确保了 `this` 绑定在 handleClick 中 // 这里只是一个测试 handleClick = () => { console.log('this is:', this); } render() { return ( <button onClick={this.handleClick}> Click me </button> ); } }

如果你没有使用属性初始化器语法,你可以在回调函数中使用 箭头函数:

class LoggingButton extends React.Component { handleClick() { console.log('this is:', this); } render() { // 这个语法确保了 `this` 绑定在 handleClick 中 return ( <button onClick={(e) => this.handleClick(e)}> Click me </button> ); } }

使用这个语法有个问题就是每次 LoggingButton 渲染的时候都会创建一个不同的回调函数。在大多数情况下,这没有问题。然而如果这个回调函数作为一个属性值传入低阶组件,这些组件可能会进行额外的重新渲染。我们通常建议在构造函数中绑定或使用属性初始化器语法来避免这类性能问题。


向事件处理程序传递参数

通常我们会为事件处理程序传递额外的参数。例如,若是 id 是你要删除那一行的 id,以下两种方式都可以向事件处理程序传递参数:

<button onClick={(e) => this.deleteRow(id, e)}>Delete Row</button> <button onClick={this.deleteRow.bind(this, id)}>Delete Row</button>

上述两种方式是等价的。

上面两个例子中,参数 e 作为 React 事件对象将会被作为第二个参数进行传递。通过箭头函数的方式,事件对象必须显式的进行传递,但是通过 bind 的方式,事件对象以及更多的参数将会被隐式的进行传递。

值得注意的是,通过 bind 方式向监听函数传参,在类组件中定义的监听函数,事件对象 e 要排在所传递参数的后面,例如:

class Popper extends React.Component{ constructor(){ super(); this.state = {name:'Hello world!'}; } preventPop(name, e){ //事件对象e要放在最后 e.preventDefault(); alert(name); } render(){ return ( <div> <p>hello</p> {/* 通过 bind() 方法传递参数。 */} <a href="https://reactjs.org" onClick={this.preventPop.bind(this,this.state.name)}>Click</a> </div> ); } }

❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

http://www.jsqmd.com/news/1017201/

相关文章:

  • LabVIEW 并行编程深度解析:Parallel For Loop 与异步调用的性能之战
  • 小白程序员必看:收藏这份RAG指南,轻松学习大模型减少幻觉的秘诀!
  • 零代码私有化自动化AI算法训练服务器DLTM如何破解企业AI落地难题
  • Forza Mods AIO架构深度解析:3大核心技术实现原理与内存修改实践指南
  • 联邦学习后门攻击防御:ProtegoFed方案解析
  • 2026年无锡中小企业数字化管理全攻略:从钉钉智连到业财人事一体化实战指南 - 优质企业观察收录
  • 按需选店不踩坑!2026 年洛阳数码维修租赁回收店实用选购指南 - 资讯纵览
  • NoFences终极指南:5分钟免费打造整洁高效的Windows桌面
  • 嵌入式以太网控制器寄存器编程实战:从MSC8113看驱动开发核心
  • Vue项目里iView Table动态列卡死?一个深拷贝操作拯救你的页面性能
  • 如何快速使用开源工具applera1n:iOS激活锁绕过的完整指南
  • java学习笔记——多线程
  • 深入解析MPC8533E:PowerQUICC III核心寄存器配置与底层驱动实战
  • 加油卡回收可行吗?深度拆解五种方式 - 猎卡网
  • 2026年硕士毕业论文AI测评:全流程覆盖,5款工具推荐
  • 中国电子学会图形化2021.9月Scratch四级考级题
  • 避坑指南:Redis GEO在Spring Boot中计算距离的3个常见错误与正确姿势
  • 2026年搜索众智商学院联系方式时怎样避开非官方信息?课程咨询渠道识别指南 - 众智商学院职业教育
  • 2026年人事业财生产一体化实战手册;无锡钉钉数字化管理系统选型指南: - 优质企业观察收录
  • MSC711x DSP系统性能调优:内存访问与DMA传输优化实战指南
  • ArcMap 10.7/10.8闪退救星:一招清理Normal.mxt模板文件,90%问题秒解
  • Visual C++运行库终极解决方案:一劳永逸的Windows系统必备神器
  • 网络分类:局域网、城域网、广域网、互联网
  • WarcraftHelper:魔兽争霸III终极性能优化与兼容性修复完全指南
  • 免费解锁Wand专业功能终极指南:告别2小时限制,畅享完整游戏体验
  • Windows系统优化新方案:智能清理“此电脑“顽固快捷方式的终极工具
  • 美团礼品卡回收实用指南 正规高价比平台推荐 - 购物卡回收找京尔回收
  • 深入解析YOLOv9:可编程梯度信息引领的信息瓶颈破解之道 —— 完整原理、实现与部署指南
  • 2026年五大有实力的电磁溢流阀专业加工品牌对比清单 - 资讯纵览
  • 2026 金价高位反复波动,无锡闲置黄金最佳出手窗口期已现 - 奢侈品回收评测