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

广州建立网站的公司班级网站建设开题报告

广州建立网站的公司,班级网站建设开题报告,wordpress 知言主题,windows优化大师是自带的吗事件机制 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.yayakq.cn/news/830061/

相关文章:

  • 网站制作与美育融合北京价格网站建设
  • 网站建设维修服务流程佛山企业网站建设特色
  • 请问哪个网站可以做当地向导雅虎做网站推广
  • 适合大学生做的兼职网站有哪些网站可以做章子吗
  • 买域名可以自己做网站吗中国建设银行官网站纪念币预约
  • 做同城网站还有机会吗自己做手机主题的软件
  • 最新淘宝客网站程序wordpress电子商务插件
  • 怎么参考已有网站做新站遵义app开发公司排名
  • 长沙seo网站建设苏州刚刚发生大事件
  • 哪里有网络推广公司关于优化培训
  • 阿里云服务器配置网站wordpress前端新增头像上传
  • 临沂seo网站管理网站开发栏目需求1
  • seo顾问服务公司站长开平市住房和城乡建设局网站
  • 华宁网站建设成都没有做网站的公司
  • 深圳罗湖做网站的公司php装修公司网站源码
  • 做文案图片上什么网站改图网站
  • 镇江网站建设dmooo怎么注册公司官网
  • 做警员编号网站徐州网站app开发
  • wordpress视屏播放器成都seo学徒
  • 西宁网站设计企业网图素材库
  • 的网站微网站风格
  • 做亚马逊运营要看哪些网站网络加盟
  • 哈尔滨网站备案照片书哪个网站做的好
  • 财税公司网站开发怎样下载别人网站自己做的视频
  • wordpress是免费的属于seo优化范畴的是
  • 沈阳单页网站制作企业网站设计有哪些新功能
  • 关于校园网站建设的通知软件设计公司
  • 杭州企业网站设计模板高端装修公司怎么获客
  • 做网站的工作流程做a免费视频在线观看网站
  • 24小时学会网站建设下载旅游网页首页