react,点击其他区域,隐藏弹窗或各种div原理

感谢:1、https://www.cnblogs.com/lihuanqing/p/6295685.html,强推

2、https://blog.csdn.net/weixin_34393428/article/details/86846971

 

这篇写给跟我一样的小白。

上面两个链接已经足够清晰,此处记录一下我个人的理解。

 

点击其他区域,隐藏div的原理:

在document上挂载监听click事件,这时候点击所有地方都会触发这个事件(事件里根据个人需求,把控制显示的变量改为false等等)

由于点击所有地方都会触发事件,所以这时点击div内部也会触发。

但那个div不能被点击事件影响,所以要在div的点击事件上添加阻止事件冒泡(e.nativeEvent.stopImmediatePropagation()),就是阻止div里的【点击】这个动作层层上传,不让这次点击被document监听到。

这样就可以完成点击div以内的区域无影响,点击外部区域隐藏div了。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值