BAE WebApp开发 [3]——WebApp事件穿透效应研究

在WebApp中,在页面转场或硬切换或弹框等界面变化的处理中,把初始界面触发界面变化事件的元素btnA相对屏幕的位置标为screenPoint,而切换的目标界面在screenPoint位置也存在一个元素btnB并绑定了事件处理(或btnB位置是一个input输入框),在一定情况下,当btnA被触发时,btnB也会被触发(或获取到焦点)。这里将这种现象成为事件穿透效应。

场景:

<div ontouchstart="$('#screenA').hide();$('#screenB').show();">btnA</div>
<div onclick="$('#screenB').hide();$('#screenA').show();">btnB</div>

在以上代码中,为btnA绑定touch事件,btnB绑定click事件。

当点击按钮btnA时,切换到screenB后,按钮btnB也接收到点击事件,页面又切换回screenA,造成了事件穿透。

 

说明:
1、第一位置——初始界面触发界面变化事件的元素btnA
2、第二位置——目标界面元素btnB

测试结果:
1、第一位置为touchstart/touchend事件,第二位置为touchstart/touchend事件,未触发透传
2、第一位置为touchstart/touchend事件,第二位置为click事件,触发透传
3、第一位置为touchstart/touchend事件,第二位置为Input元素,触发透传
4、第一位置为click事件,第二位置为touchstart/touchend事件,未触发透传
5、第一位置为click事件,第二位置为click事件,未触发透传

结论:
1、第一位置与第二位置使用相同类型(即:非click即touch)的事件
2、第二位置为input元素时,第一位置使用click事件

以上为初步测试结果,有待更进一步研究。
大家可以根据测试结果,修改代码并测试,如有问题,请及时反馈。

posted @   plums  阅读(1955)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示