mouseup 事件丢失的原因和解决办法
来源:互联网 发布:mysql存储过程for循环 编辑:程序博客网 时间:2024/05/21 04:21
说明
当实现类似Excel选中区域的功能时,经常出现 mouseup 事件丢失的情况,由于缺少了 mouseup 事件,导致一个完整的操作无法进行。
如果你是想进行拖拽移动操作,也可以参考本文。
原因
目前发现两个原因:
- 触发了浏览器的 drag 操作,导致mouseup丢失。
- 由于鼠标离开了操作的区域,触发了mouseleave导致mouseup丢失。
解决办法
第一种情况
通过执行下面的代码阻止系统默认的操作来防止触发 drag 操作:
//在事件中e=e || window.event;pauseEvent(e);//阻止事件冒泡//不仅仅要stopPropagation,还要preventDefaultfunction pauseEvent(e){ if(e.stopPropagation) e.stopPropagation(); if(e.preventDefault) e.preventDefault(); e.cancelBubble=true; e.returnValue=false; return false;}
通过对事件调用pauseEvent
方法可以防止出现drag操作,因此在区域内可以避免mouseup丢失。即使你想实现的本来就是 drag 操作,也可以通过创建跟随鼠标移动的dom元素实现效果。
参考地址:
http://stackoverflow.com/questions/5429827/how-can-i-prevent-text-element-selection-with-cursor-drag
第二种情况
由于鼠标移到了区域外,触发了 mouseleave 操作,因此在这种情况下要监听 mouseleave 操作,当触发该操作时可以停止或者还原状态。
特别注意的地方
当处理鼠标事件时,可以还要考虑是否要控制按下那个键时才允许操作。
Mouse事件中有一个 buttons
属性,该值标示鼠标按下了一个或者多个按键,如果按下的键为多个,值则为多个:
- 0 : 没有按键或者是没有初始化
- 1 : 鼠标左键
- 2 : 鼠标右键
- 4 : 鼠标滚轮或者是中键
- 8 : 第四按键 (通常是“浏览器后退”按键)
- 16 : 第五按键 (通常是“浏览器前进”)
多个值的时候,相当于进行|
操作,即鼠标左右键同时按下时1|2=3
。判断是否按下左键可以用value&1!=0
进行,例如左右键同时按下时3&1!=0
是true
,说明按下了左键。
部分内容参考:
https://developer.mozilla.org/zh-CN/docs/Web/API/MouseEvent/buttons
0 0
- mouseup 事件丢失的原因和解决办法
- 拖动div时鼠标mouseup事件丢失
- VC中按钮的MouseDown和MouseUp事件捕捉
- Frameset导致Cookies和Session丢失的原因及解决办法
- Frameset导致Cookies和Session丢失的原因及解决办法
- Frameset导致Cookies和Session丢失的原因及解决办法
- 控件的mouseUp事件无效问题
- Maxthon收藏丢失的原因及解决办法
- Session丢失的原因及解决办法
- Session莫名丢失的原因及解决办法
- ViewPager 丢失监听事件的原因之一
- slider 滑动条 mouseup有时失效的原因
- jquery 触发 mouseup 事件
- asp.net在IE10下事件丢失的原因分析
- mousedown\mouseup\click事件关系
- DataGrid的一些 事件会经常丢失的解决办法
- 丢失PID的原因
- Extjs鼠标长按事件(实现长按按钮触发事件的方法:mousedown、mouseup)
- 90.Java处理数据库中的Clob对象【ClobtoString】
- 如何在myeclipse中添加Python插件
- web数据传输
- ORACLE DATABASE 11G RAC 知识图文详细教程之RAC 特殊问题和实战经验(五)
- MTK Android 菜鸟上手之旅
- mouseup 事件丢失的原因和解决办法
- Android插件化基础之加载未安装的apk资源
- Creates a pipe for reading and writing的例子程序
- 三范式与反三范式
- 给定一个数字n, 等概率输出1-n的值,要求最后全都输出一遍
- Maven项目中java类报错-Cannot resolve symbol
- 【JAVA】数组搜索查询字符内容
- 流媒体相关 概念
- C++ 标准库中函数所对应的头文件