合成事件与原生事件 区别:
1. 命名不一样,原生用纯小写方式,react用小驼峰的方式
原生:onclick React的:onClick
2. 事件处理函数的写法不一样
原生的是传入一个字符串,react写法传入一个回调函数
3. 阻止默认行为方式不同
原生:return false, react中的:event.preventDefault()
javascriptclass 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 ( // class的方法默认不会绑定this。如果没有绑定this.handleClick.bind(this) 并把它传入 onClick,this的值为undefined <Button onClick={this.handleClick}> // 2. 传入一个回调函数 {this.state.isToggleOn ? 'ON' : 'OFF'} </Button> // 1. onClick小驼峰写法 ) } }【 拓展:为什么需要绑定this 】
button按钮编译的过程:React.createElement()
javascript// 伪代码 // 证明为什么绑定this function creteElement (dom, params) { var domObj = document.createElement(dom) domObj.onClick = params.onClick // 后面的onClick(当前的onClick函数)赋值给前面的onClick, 这时,onClick执行的作用域是外层作用域。所以return出去的值找不到this.handleClick。[所以需要绑定this指定到当前的作用域] domObj.innerHTML = params.content return domObj } React.creteElement('button', { onClick: this.handleClick }, this.state.isToggleOn ? 'ON' : 'OFF')如果不想绑定this的写法:
javascriptclass Toggle extends React.Component { constructor(props) super(props) this.state={ isToggleOn: true } // 法1:bind绑定:为了在回调中使用this, 这个绑定是必不可少的 // this.handleClick = this.handleClick.bind(this) handleClick = () => { // 法2:写成箭头函数,箭头函数没有作用域的 this.setState((prevState) => ({ isToggleOn: !prevState.isToggleOn })) } render(){ return ( // class的方法默认不会绑定this。如果没有绑定this.handleClick.bind(this) 并把它传入 onClick,this的值为undefined <Button onClick={() => this.handleClick()}> // 2. 传入一个回调函数 法3 {this.state.isToggleOn ? 'ON' : 'OFF'} </Button> // 1. onClick小驼峰写法 ) } }. 为何React要用合成事件机制
进行浏览器兼容、跨平台、事件代理(移动端和pc端的一些原生事件不一定完全兼容的)
挂载到documnet,减少内存消耗,避免频繁绑定和解绑事件,也方便事件统一管理
避免垃圾回收、react事件池
React中的合成事件
outstanding木槿2025-01-06 10:19
相关推荐
REDcker4 分钟前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单donecoding2 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复风骏时光牛马2 小时前
Raku正则匹配与数据批量处理实操案例nbwenren2 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码Lee川2 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库Linsk2 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?当时只道寻常2 小时前
浏览器文本复制到剪贴板:企业级最佳实践jinanwuhuaguo2 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”广州华水科技2 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚