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事件
以上为初步测试结果,有待更进一步研究。
大家可以根据测试结果,修改代码并测试,如有问题,请及时反馈。
分类:
BAE WebApp开发
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库