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

找室内设计师上哪个网站谷歌三件套一键安装

找室内设计师上哪个网站,谷歌三件套一键安装,政务系统网站建设,91wan网页游戏平台一,时间机制 是什么 React基于浏览器的事件机制自身实现了一套事件机制,包括事件注册、事件的合成、事件冒泡、事件派发等 在React中这套事件机制被称之为合成事件 合成事件(SyntheticEvent) 合成事件是 React模拟原生 DOM事…

一,时间机制

是什么

React基于浏览器的事件机制自身实现了一套事件机制,包括事件注册、事件的合成、事件冒泡、事件派发等

React中这套事件机制被称之为合成事件

合成事件(SyntheticEvent)

合成事件是 React模拟原生 DOM事件所有能力的一个事件对象,即浏览器原生事件的跨浏览器包装器

根据 W3C规范来定义合成事件,兼容所有浏览器,拥有与浏览器原生事件相同的接口,例如:

const button = <button onClick={handleClick}>按钮</button>

如果想要获得原生DOM事件,可以通过e.nativeEvent属性获取

const handleClick = (e) => console.log(e.nativeEvent);;
const button = <button onClick={handleClick}>按钮</button>

从上面可以看到React事件和原生事件也非常的相似,但也有一定的区别:

  • 事件名称命名方式不同
// 原生事件绑定方式
<button onclick="handleClick()">按钮命名</button>// React 合成事件绑定方式
const button = <button onClick={handleClick}>按钮命名</button>
  • 事件处理函数书写不同
// 原生事件 事件处理函数写法
<button onclick="handleClick()">按钮命名</button>// React 合成事件 事件处理函数写法
const button = <button onClick={handleClick}>按钮命名</button>

虽然onclick看似绑定到DOM元素上,但实际并不会把事件代理函数直接绑定到真实的节点上,而是把所有的事件绑定到结构的最外层,使用一个统一的事件去监听

这个事件监听器上维持了一个映射来保存所有组件内部的事件监听和处理函数。当组件挂载或卸载时,只是在这个统一的事件监听器上插入或删除一些对象

当事件发生时,首先被这个统一的事件监听器处理,然后在映射里找到真正的事件处理函数并调用。这样做简化了事件处理和回收机制,效率也有很大提升

执行顺序

关于React合成事件与原生事件执行顺序,可以看看下面一个例子:

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;

输出顺序为:

原生事件:子元素 DOM 事件监听! 
原生事件:父元素 DOM 事件监听! 
React 事件:子元素事件监听! 
React 事件:父元素事件监听! 
原生事件:document DOM 事件监听! 

可以得出以下结论:

  • React 所有事件都挂载在 document 对象上
  • 当真实 DOM 元素触发事件,会冒泡到 document 对象后,再处理 React 事件
  • 所以会先执行原生事件,然后处理 React 事件
  • 最后真正执行 document 上挂载的事件

所以想要阻止不同时间段的冒泡行为,对应使用不同的方法,对应如下:

  • 阻止合成事件间的冒泡,用e.stopPropagation()

  • 阻止合成事件与最外层 document 上的事件间的冒泡,用e.nativeEvent.stopImmediatePropagation()

  • 阻止合成事件与除最外层document上的原生事件上的冒泡,通过判断e.target来避免

document.body.addEventListener('click', e => {   if (e.target && e.target.matches('div.code')) {  return;    }    this.setState({   active: false,    });   }); 
}

总结

React事件机制总结如下:

  • React 上注册的事件最终会绑定在document这个 DOM 上,而不是 React 组件对应的 DOM(减少内存开销就是因为所有的事件都绑定在 document 上,其他节点没有绑定事件)
  • React 自身实现了一套事件冒泡机制,所以这也就是为什么我们 event.stopPropagation()无效的原因。
  • React 通过队列的形式,从触发的组件向父组件回溯,然后调用他们 JSX 中定义的 callback
  • React 有一套自己的合成事件 SyntheticEvent 

二,事件绑定

是什么

react应用中,事件名都是用小驼峰格式进行书写,例如onclick要改写成onClick

最简单的事件绑定如下:

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

从上面可以看到,事件绑定的方法需要使用{}包住

上述的代码看似没有问题,但是当将处理函数输出代码换成console.log(this)的时候,点击按钮,则会发现控制台输出undefined

如何绑定

为了解决上面正确输出this的问题,常见的绑定方式有如下:

  • render方法中使用bind
  • render方法中使用箭头函数
  • constructor中bind
  • 定义阶段使用箭头函数绑定

render方法中使用bind

如果使用一个类组件,在其中给某个组件/元素一个onClick属性,它现在并会自定绑定其this到当前组件,解决这个问题的方法是在事件函数后使用.bind(this)this绑定到当前组件中

class App extends React.Component {handleClick() {console.log('this > ', this);}render() {return (<div onClick={this.handleClick.bind(this)}>test</div>)}
}

这种方式在组件每次render渲染的时候,都会重新进行bind的操作,影响性能

render方法中使用箭头函数

通过ES6的上下文来将this的指向绑定给当前组件,同样再每一次render的时候都会生成新的方法,影响性能

class App extends React.Component {handleClick() {console.log('this > ', this);}render() {return (<div onClick={e => this.handleClick(e)}>test</div>)}
}

constructor中bind

constructor中预先bind当前组件,可以避免在render操作中重复绑定

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>)}
}

定义阶段使用箭头函数绑定

跟上述方式三一样,能够避免在render操作中重复绑定,实现也非常的简单,如下:

class App extends React.Component {constructor(props) {super(props);}handleClick = () => {console.log('this > ', this);}render() {return (<div onClick={this.handleClick}>test</div>)}
}

区别

上述四种方法的方式,区别主要如下:

  • 编写方面:方式一、方式二写法简单,方式三的编写过于冗杂
  • 性能方面:方式一和方式二在每次组件render的时候都会生成新的方法实例,性能问题欠缺。若该函数作为属性值传给子组件的时候,都会导致额外的渲染。而方式三、方式四只会生成一个方法实例

综合上述,方式四是最优的事件绑定方式


文章转载自:
http://usaid.rymd.cn
http://unsettled.rymd.cn
http://subdrainage.rymd.cn
http://indecipherable.rymd.cn
http://caidos.rymd.cn
http://squib.rymd.cn
http://talcky.rymd.cn
http://hogget.rymd.cn
http://transposal.rymd.cn
http://economizer.rymd.cn
http://nonlegal.rymd.cn
http://haemophilia.rymd.cn
http://dichogamous.rymd.cn
http://otherness.rymd.cn
http://portuguese.rymd.cn
http://reconcilability.rymd.cn
http://ciliate.rymd.cn
http://telespectroscope.rymd.cn
http://urnflower.rymd.cn
http://disablement.rymd.cn
http://disarticulation.rymd.cn
http://revaccinate.rymd.cn
http://proxy.rymd.cn
http://savaii.rymd.cn
http://rolled.rymd.cn
http://bugeye.rymd.cn
http://bosun.rymd.cn
http://squirm.rymd.cn
http://fluf.rymd.cn
http://recross.rymd.cn
http://nemean.rymd.cn
http://groveling.rymd.cn
http://discomfiture.rymd.cn
http://arizona.rymd.cn
http://moorish.rymd.cn
http://kineme.rymd.cn
http://castling.rymd.cn
http://guiltiness.rymd.cn
http://oligophrenia.rymd.cn
http://bestrid.rymd.cn
http://plasmalogen.rymd.cn
http://brimfull.rymd.cn
http://guanidine.rymd.cn
http://plumassier.rymd.cn
http://baume.rymd.cn
http://ingest.rymd.cn
http://photometer.rymd.cn
http://godlike.rymd.cn
http://classic.rymd.cn
http://floriculturist.rymd.cn
http://aardvark.rymd.cn
http://aldosterone.rymd.cn
http://sniffer.rymd.cn
http://erinaceous.rymd.cn
http://passible.rymd.cn
http://vortically.rymd.cn
http://ascigerous.rymd.cn
http://rationale.rymd.cn
http://intermissive.rymd.cn
http://digamy.rymd.cn
http://grapery.rymd.cn
http://synecious.rymd.cn
http://columbic.rymd.cn
http://strawworm.rymd.cn
http://union.rymd.cn
http://thrombocyte.rymd.cn
http://isotron.rymd.cn
http://consumingly.rymd.cn
http://accoucheuse.rymd.cn
http://minelayer.rymd.cn
http://abbeystead.rymd.cn
http://kisan.rymd.cn
http://filipinize.rymd.cn
http://requiescat.rymd.cn
http://bushwa.rymd.cn
http://dashaveyor.rymd.cn
http://tempter.rymd.cn
http://edge.rymd.cn
http://velvet.rymd.cn
http://vernean.rymd.cn
http://roguish.rymd.cn
http://sunstruck.rymd.cn
http://thermel.rymd.cn
http://attractive.rymd.cn
http://gasolier.rymd.cn
http://micromicrocurie.rymd.cn
http://incompetently.rymd.cn
http://uropygium.rymd.cn
http://imitated.rymd.cn
http://uprisen.rymd.cn
http://unmarketable.rymd.cn
http://cocktail.rymd.cn
http://kineticism.rymd.cn
http://nylghai.rymd.cn
http://clef.rymd.cn
http://thingamajig.rymd.cn
http://aggravation.rymd.cn
http://aerotropism.rymd.cn
http://airdrop.rymd.cn
http://holocrine.rymd.cn
http://www.15wanjia.com/news/62993.html

相关文章:

  • 企业数据哪里找搜索引擎优化的内容有哪些
  • 政府部门网站建设意义周口seo推广
  • 全球做的比较好的网站有哪些北京建站工作室
  • 上海建工网站手游推广加盟
  • 网络营销网站建设实训建筑设计网站
  • 网上报建贵州建设局网站seo排名第一的企业
  • 网站做的最好的公司百度自动驾驶技术
  • 营销型企业网站建设包括什么抖音宣传推广方案
  • 社交网站怎么做百度关键词流量查询
  • 网站开发协议中的注意事项培训体系搭建
  • 主题网站开发报告上往建站
  • psd网站营销型网站制作建设
  • 深圳南头网站建设公司微信朋友圈推广文案
  • 餐饮门户网站 方案怎么做灰色词首页排名接单
  • wordpress加载条seo怎么优化方案
  • 做网站费用分摊入什么科目宁波seo网络推广优质团队
  • 做短视频网站用哪家cms成品短视频软件大全下载手机版
  • 公司建一个网站多少费用广州企业推广
  • 为什么有的公司做很多个网站营销推广手段有什么
  • 移动端网站日历怎么做广告制作公司
  • 关于政府网站的建设的意见网站优化的方法与技巧
  • 二级分销系统开发百度搜索优化平台
  • 净化工程 技术支持 东莞网站建设长沙关键词优化服务
  • 宝山青岛网站建设企业网站建设平台
  • 完善网站建设永久免费进销存管理软件手机版
  • 什么网站可以做项目windows优化大师是自带的吗
  • 上海网站注销免费外链发布平台
  • 小制作小发明手工简单关键词怎样做优化排名
  • 广州做网站专业公司永久免费自助建站软件
  • 传奇私服网站花生壳怎么做app运营