mouseup事件丢失的原因和解决办法

mouseup事件丢失的原因和解决办法
说明
当实现类似Excel选中区域的功能时,经常出现 mouseup 事件丢失的情况,由于缺少了 mouseup 事件,导致⼀个完整的操作⽆法进⾏。
如果你是想进⾏拖拽移动操作,也可以参考本⽂。
原因
⽬前发现两个原因:
1. 触发了浏览器的 drag 操作,导致mouseup丢失。
鼠标跟随
2. 由于⿏标离开了操作的区域,触发了mouseleave导致mouseup丢失。
解决办法
第⼀种情况
通过执⾏下⾯的代码阻⽌系统默认的操作来防⽌触发 drag 操作:
//在事件中
e=e || window.event;
pauseEvent(e);
//阻⽌事件冒泡
//不仅仅要stopPropagation,还要preventDefault
function pauseEvent(e){
if(e.stopPropagation) e.stopPropagation();
导线测量法
if(e.preventDefault) e.preventDefault();
e.cancelBubble=true;
return false;
}
通过对事件调⽤pauseEvent⽅法可以防⽌出现drag操作,因此在区域内可以避免mouseup丢失。即使你想实现的本来就是 drag 操作,也可以通过创建跟随⿏标移动的dom元素实现效果。
参考地址:
第⼆种情况
由于⿏标移到了区域外,触发了 mouseleave 操作,因此在这种情况下要监听 mouseleave 操作,当触发该操作时可以停⽌或者还原状态。
特别注意的地⽅
牧一征
当处理⿏标事件时,可以还要考虑是否要控制按下那个键时才允许操作。
Mouse事件中有⼀个 buttons 属性,该值标⽰⿏标按下了⼀个或者多个按键,如果按下的键为多个,值则为多个:手持gps怎么量测
0 : 没有按键或者是没有初始化
1 : ⿏标左键
2 : ⿏标右键
人工天竺黄
4 : ⿏标滚轮或者是中键
8 : 第四按键 (通常是“浏览器后退”按键)
16 : 第五按键 (通常是“浏览器前进”)
多个值的时候,相当于进⾏|操作,即⿏标左右键同时按下时1|2=3。判断是否按下左键可以⽤value&1!=0进⾏,例如左右键同时按下时3&1!=0是true,说明按下了左键。
部分内容参考:

本文发布于:2024-09-22 16:33:49,感谢您对本站的认可!

本文链接:https://www.17tex.com/tex/2/339026.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:操作   区域   丢失   事件   触发   是否
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议