万网如何上传网站,企业文化 设计 咨询,做网站开发需要什么证书,比特币简易网站开发这篇文章主要跟大家介绍了关于Javascript中mouseup事件丢失的原因与解决办法的相关资料#xff0c;文中给出详细的示例代码供大家参考学习#xff0c;需要的朋友们下面跟着小编一起来学习学习吧。前言当实现类似Excel选中区域的功能时#xff0c;经常出现 mouseup 事件丢失的…这篇文章主要跟大家介绍了关于Javascript中mouseup事件丢失的原因与解决办法的相关资料文中给出详细的示例代码供大家参考学习需要的朋友们下面跟着小编一起来学习学习吧。前言当实现类似Excel选中区域的功能时经常出现 mouseup 事件丢失的情况由于缺少了 mouseup 事件导致一个完整的操作无法进行。如果你是想进行拖拽移动操作也可以参考本文。原因目前发现两个原因触发了浏览器的 drag 操作导致mouseup丢失。由于鼠标离开了操作的区域触发了mouseleave导致mouseup丢失。解决办法第一种情况通过执行下面的代码阻止系统默认的操作来防止触发 drag 操作//在事件中ee || window.event;pauseEvent(e);//阻止事件冒泡//不仅仅要stopPropagation还要preventDefaultfunction pauseEvent(e){if(e.stopPropagation) e.stopPropagation();if(e.preventDefault) e.preventDefault();e.cancelBubbletrue;e.returnValuefalse;return false;}通过对事件调用pauseEvent方法可以防止出现drag操作因此在区域内可以避免mouseup丢失。即使你想实现的本来就是 drag 操作也可以通过创建跟随鼠标移动的dom元素实现效果。第二种情况由于鼠标移到了区域外触发了 mouseleave 操作因此在这种情况下要监听 mouseleave 操作当触发该操作时可以停止或者还原状态。特别注意的地方当处理鼠标事件时可以还要考虑是否要控制按下那个键时才允许操作。Mouse事件中有一个 buttons 属性该值标示鼠标按下了一个或者多个按键如果按下的键为多个值则为多个0 : 没有按键或者是没有初始化1 : 鼠标左键2 : 鼠标右键4 : 鼠标滚轮或者是中键8 : 第四按键 (通常是“浏览器后退”按键)16 : 第五按键 (通常是“浏览器前进”)多个值的时候相当于进行|操作即鼠标左右键同时按下时1|23。判断是否按下左键可以用value1!0进行例如左右键同时按下时31!0是true说明按下了左键。总结