这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
这篇文章主要跟大家介绍了关于 Javascript 中 mouseup 事件丢失的原因与解决办法的相关资料,文中给出详细的示例代码供大家参考学习,需要的朋友们下面跟着小编一起来学习学习吧。
前言
当实现类似 Excel 选中区域的功能时,经常出现 mouseup 事件丢失的情况,由于缺少了 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;
- e.returnValue = false;
- return false;
- }
通过对事件调用 pauseEvent 方法可以防止出现 drag 操作,因此在区域内可以避免 mouseup 丢失。即使你想实现的本来就是 drag 操作,也可以通过创建跟随鼠标移动的 dom 元素实现效果。
第二种情况
由于鼠标移到了区域外,触发了 mouseleave 操作,因此在这种情况下要监听 mouseleave 操作,当触发该操作时可以停止或者还原状态。
特别注意的地方
当处理鼠标事件时,可以还要考虑是否要控制按下那个键时才允许操作。
Mouse 事件中有一个 buttons 属性,该值标示鼠标按下了一个或者多个按键,如果按下的键为多个,值则为多个:
0 : 没有按键或者是没有初始化
1 : 鼠标左键
2 : 鼠标右键
4 : 鼠标滚轮或者是中键
8 : 第四按键 (通常是" 浏览器后退 "按键)
16 : 第五按键 (通常是" 浏览器前进 ")
多个值的时候,相当于进行 | 操作,即鼠标左右键同时按下时 1|2=3。判断是否按下左键可以用 value&1!=0 进行,例如左右键同时按下时 3&1!=0 是 true,说明按下了左键。
总结
来源: http://www.phperz.com/article/17/0816/338678.html