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

中山网站建设价位百度app客服人工电话

中山网站建设价位,百度app客服人工电话,外贸网络推广公司排名,珠海网站制作服务事件机制 react 基于浏览器的事件机制自身实现了一套事件机制,称为合成事件。比如:onclick -> onClick 获取原生事件:e.nativeEvent onClick 并不会将事件代理函数绑定到真实的 DOM节点上,而是将所有的事件绑定到结构的最外层…

事件机制

react 基于浏览器的事件机制自身实现了一套事件机制,称为合成事件。比如:onclick -> onClick

获取原生事件:e.nativeEvent

onClick 并不会将事件代理函数绑定到真实的 DOM节点上,而是将所有的事件绑定到结构的最外层(document,减少内存开销),使用一个统一的事件去监听。事件监听器维持了一个映射保存所有组件内部的事件监听和处理函数,当组件挂载或者卸载时,在事件监听器上插入或者删除一些对象。(简化了事件处理和回收机制,提升效率)

事件发生 -> 事件处理器 -> 映射真实事件处理函数并调用

原生和合成事件执行顺序:

import React from 'react';
class App extends React.Component{constructor(props) {super(props);this.parentRef = React.createRef();this.childRef = React.createRef();}componentDidMount() {console.log("React componentDidMount ");this.parentRef.current?.addEventListener("click", () => {console.log(" DOM ");});this.childRef.current?.addEventListener("click", () => {console.log(" DOM ");});document.addEventListener("click", (e) => {console.log(" document DOM ");});}parentClickFun = () => {console.log("React ");};childClickFun = () => {console.log("React ");};render() {return (<div ref={this.parentRef} onClick={this.parentClickFun}><div ref={this.childRef} onClick={this.childClickFun}></div></div>);}
}
export default App;

输出结果为:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

所以:

  • react 所有事件都挂载到 document 对象上
  • 真实 DOM 元素触发事件,冒泡到 document 对象上,再处理 react 事件
  • 最后真正执行 document 上挂载的事件

阻止不同阶段的事件冒泡:

  • 阻止合成事件间的冒泡,用 e.stopPropagation()
  • 阻止合成事件与最外层document上的事件间的冒泡,用 e.nativeEvent.stoplmmediatePropagation()
  • 阻止合成事件与除最外层document.上的原生事件上的冒泡,通过判断e.target3来避免

事件绑定(this)

class ShowAlert extends React.Component {showAlert() {console.log(this);  // undefined}render() {return <button onClick={this.showAlert}>show</button>;}
}

为了解决没有绑定 this 问题,有四种方法。

// render 方法使用 this:
class App extends React.Component {handleClick() {console.log('this > ', this);}render() { // 每次 render 的时候 都会重新进行 bind 的绑定 影响性能return (<div onClick={this.handleClick.bind(this)}>test</div>)}
}
// render 中使用箭头函数
class App extends React.Component {handleClick() {console.log('this > ', this);}render() {return (<div onClick={e => this.handleClick(e)}>test</div>)}
}
// constructor 中使用 bind
class App extends React.Component {constructor(props) {super(props);this.handleClick = this.handleClick.bind(this);}handleClick() {console.log('this > ', this);}render() {return (<div onClick={this.handleClick}>test</div>)}
}
// 函数定义阶段使用箭头函数
class App extends React.Component {constructor(props) {super(props);}handleClick = () => {console.log('this > ', this);}render() {return (<div onClick={this.handleClick}>test</div>)}
}
http://www.hengruixuexiao.com/news/51286.html

相关文章:

  • 国外知名平面设计网站老客外链
  • 兰溪做网站系统优化方法
  • 范县网站建设专业seo培训学校
  • 重庆铜梁网站建设建网站用什么工具
  • 17网站一起做网店怎么拿货培训总结
  • 网站建设与规划总结怎么写宁波seo网络推广推荐
  • 网站备案 中国最新疫情最新消息
  • 上海市政府网站建设具体桌子seo关键词
  • 网站建设及推广方案私域流量和裂变营销
  • 自动优化网站建设咨询快速优化排名公司推荐
  • 辽宁网站网站建设快速优化工具
  • php网站怎么做post订单优化关键词可以选择哪个工具
  • 学生做家教网站百度app下载官方免费下载安装
  • 佛山信息技术网站开发线上销售平台如何推广
  • JAVA做论坛网站的源代码微信推广怎么弄
  • 网站建设捌金手指花总十三软件排名优化
  • 旅游网站建设分析 需求南宁seo营销推广
  • 汕头网站推广系统百度关键词搜索排行
  • 嘉兴专业网站排名推广公司策划推广
  • 一屏展示网站网站优化建设
  • 北京城乡建设委官方网站招聘网络营销推广人员
  • 照片变年轻在线制作网站南昌百度seo
  • 平昌城乡与住房建设部网站网站优化推广软件
  • 做html网站搜索框代码google关键词
  • 佛山外贸网站建设方案营销咨询
  • 公司可以做网站百度指数的需求指数
  • 糗事百科 wordpress班级优化大师网页版登录
  • 用dw做php网站百度数据
  • 网站导航容易做网络营销策划书3000字
  • 什么是网络设计原则seo是什么岗位简称