React native如何让点击事件穿透遮罩层(水印)- pointerEvents属性应用

49 篇文章 4 订阅
36 篇文章 1 订阅

假如你有这么一个需求,你需要为一个页面生成水印,水印需要浮在最上层,那如何保证水印不会遮盖底层的内容呢?也就是我们要讲的 “事件穿透”

 

在PC网页中,直接生成的是浏览器的dom元素进行排列绘制

因此可以利用css自带的属性: pointer-events: none;

遮罩层容器添加一条css属性 pointer-events: none, 遮罩下的就可以点击了,IE11+支持

 

而React-Native则比较特殊,他毕竟不是运行在浏览器上的,他只是实现了Android和Ios底层View组件的UI框架

但是他也为我们提供了一份解决方案:View组件的pointerEvents属性

来自官网的介绍:用于控制当前视图是否可以作为触控事件的目标(特别注意 不要写Touchablexxx组件进行测试,因为这个组件本身就是要被点击触发的)

auto:视图可以作为触控事件的目标。
none:视图不能作为触控事件的目标。
box-none:视图自身不能作为触控事件的目标,但其子视图可以

<View pointerEvents="none">
  // something View Component
</View>

RN未必能支持原生js阻止事件冒泡、捕获、穿透等等,而且写起来比较麻烦,不推荐

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hzxOnlineOk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值