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

佛山网站建设网络公司/列举网络推广的方式

佛山网站建设网络公司,列举网络推广的方式,线上营销手段,海口招商建设有限公司网站前言 故事的开头是这样的:写业务的过程中,发现在React的onClick的回调函数里,用stopPropagation阻止绑定在document上的事件的时候,是没办法做到的,只可以阻止outClick事件的触发。详情如下:class ExampleA…

前言

故事的开头是这样的:写业务的过程中,发现在React的onClick的回调函数里,用stopPropagation阻止绑定在document上的事件的时候,是没办法做到的,只可以阻止outClick事件的触发。详情如下:
class ExampleApplication extends React.Component {componentDidMount() {document.addEventListener('click', () => {alert('document click');})}outClick(e) alert('outClick');}onClick(e) {alert('onClick');e.stopPropagation();}render() {return <div onClick={this.outClick}><button onClick={this.onClick}> 测试click事件 </button></div>}
}

这个例子最终会输出:

onClick, documentClick

关于这个问题的解释,网上五花八门,有些将其归结为是由于事件绑定快慢的原因,例如这篇文章里说

 

我们直接在jsx模板上绑定的事件,都是委托在了document上,那自然要比直接在dom上绑定的事件慢了,等document收到事件后才去e.stopPropagation(),太晚了

 

其实我们仔细想想:React在首次渲染的时候,就会执行事件的绑定,如果是由于绑定快慢的问题导致的话,应该先输出documentClick, 在输出onClick,所以由上面例子的输出可知,并不是因为document收到事件快慢的原因而导致这个问题。

真相

真相只有一个,那就是:

出现上述bug的主要原因是混用浏览器原生事件跟React合成事件

详细解释:React有自己的一套事件处理机制,它会将所有的事件都绑定在document上,然后再用dispatchEvent统一分发,这时候分发的是合成事件。

而onClick(e)这时候拿到的e其实是合成事件,只能阻止合成事件的冒泡。

 

图片来源:https://fabiaoqing.com/biaoqing/detail/id/85424.html

 

我们当然不是那么随便的人,随便起来。。。不好意思说多了,还是举个栗子先来简单验证一下吧:

class ExampleApplication extends React.Component {componentDidMount() {document.addEventListener('click', () => {alert('document click');})document.getElementById('div1').addEventListener('click', () => {alert('原生outClick');})}outClick(e) {console.log(e.currentTarget)alert('合成outClick');}onClick(e) {console.log(e.currentTarget);alert('onClick');e.stopPropagation();}render() {return <div id="div1" onClick={this.outClick}><button onClick={this.onClick}> 测试click事件 </button></div>}
}

 

做了点小改动,就是外层的div绑定的函数用原生的方式跟jsx的方式都绑定一次,所以最终的输出为

'原生outClick', 'onClick','document click'

所以button回调函数里的stopPropagation只能阻止合成事件的冒泡,而对于原生绑定的,则不行。

解决方法

解决方法有几种,我个人认为最简单的就是直接在onClick里利用event.stopImmediatePropagation。原理是这样的:

对于例子一里,document其实绑定了两种事件:

// react 合成事件, dispatchEvent里面执行回调函数
document.addEventListener('click', dispatchEvent);// 浏览器原生
document.addEventListener('click', () => {alert('document click');
})

 

而dispatchEvent里的stopImmediatePropagation可以使得绑定在document上的其他事件不会被触发

    onClick(e) {console.log(e.currentTarget);alert('onClick');e.nativeEvent.stopImmediatePropagation();}

 

当然本篇文章只是为了抛砖引玉,重点是下一篇的react事件机制,欢迎继续收看。

 

图片来源:谢谢大家捧场!

原文https://zhuanlan.zhihu.com/p/42959051

http://www.lbrq.cn/news/1460143.html

相关文章:

  • 网站建设温州/如何自己做网站
  • 浦口做网站价格/江苏seo外包
  • 网上有女的叫你建网站/微信广告投放推广平台多少费用
  • 南京高端网站建设工作室/拉新平台哪个好佣金高
  • php开发微网站开发/长沙网络营销外包哪家好
  • 美工做图详情页设计/什么叫seo网络推广
  • 怎样把自己做的网站发布/怎么把广告发到各大平台
  • 快速搭建网站 数据存储/百度发布
  • 网站开发和前端和数据媒体/全球搜官网
  • 网站空间服务器排名/公司怎么推广网络营销
  • 太原网站建设优化/营销型网站开发公司
  • 电脑手机网站制作/市场调研问卷调查怎么做
  • visual studio 开发网站开发/无锡百度竞价公司
  • 网站建设登录注册怎么做/排行榜哪个网站最好
  • 英文建设网站/百度搜索引擎优化指南最新版
  • 理卖做各视频网站的会员/如何推广网页
  • 达州市建设局网站/网上销售
  • 禅城网站建设代理/新闻联播直播 今天
  • 深圳专业企业网站建/上海百度推广排名优化
  • 南阳教育网站平台/佛山网络推广哪里好
  • 广州网络公司网络推广/上海网络seo优化公司
  • 华为手机官方网站登录/app推广全国代理加盟
  • 江西建设质量检测网站/浙江疫情最新情况
  • 重庆平台网站建设费用/win7系统优化工具
  • 怎么做诚信通网站的店招/有没有购买链接
  • 北京建设网站公司推荐/重庆seo网络优化咨询热线
  • wordpress cdn 腾讯云/上海seo外包
  • 园林景观 网站建设/2022最新热点事件及点评
  • 那个网站销售好/日照高端网站建设
  • 专业做网站厂家/武汉大学人民医院官网
  • Android 之 MVC架构
  • ulimit参数使用详细总结
  • MVCC:数据库事务隔离的 “时空魔法”
  • python工具方法51 视频数据的扩充(翻转、resize、crop、re_fps)
  • React ahooks——副作用类hooks之useThrottleEffect
  • PyTorch 张量核心操作——比较、排序与数据校验