javascript实现禁止鼠标滚轮事件


Posted in Javascript onJuly 24, 2015

平时我们兼容什么东西总是在调整低版本IE的兼容性,但是这回不是因为低版本浏览器不给力。而是因为火狐给力过头了,完全不顾其它浏览器的感受标新立异了。除了火狐之外,所有的浏览器都可以使用MouseWheel事件来处理鼠标滚轮的响应。但是火狐却偏偏不支持MouseWheel,而使用无厘头的DOMMouseScroll,这玩意儿除了火狐以外其它浏览器都不兼容。也就是说,对于鼠标滚轮事件的处理,火狐只能使用DOMMouseScroll。而非火狐则只能使用MouseWheel。这两种事件实现的原理不同,他们处理的数据也不同。

var firefox = navigator.userAgent.indexOf('Firefox') != -1;
firefox ? img.addEventListener('DOMMouseScroll', MouseWheel, false) : 
     (img.onmousewheel = MouseWheel);
 
  function MouseWheel(e) {
    e = e || window.event;
 
    if (e.stopPropagation) e.stopPropagation();
    else e.cancelBubble = true;
     
    if (e.preventDefault) e.preventDefault();
    else e.returnValue = false;
 
  }

我们来看个完整的代码

<!DOCTYPE html>
<style>
span {font:14px/20px 微软雅黑;}
#counter {
 width:50px;height:20px;
 border:1px solid #CCC;
 background:#F9F9F9;
 font:14px/20px Consolas;
 text-align:center;
 margin:10px;
}
</style>
<span>使用鼠标滚轮调整数值大小</span><br/>
<div id="counter">0</div>
<script>
//判断浏览器
var isIE=navigator.userAgent.match(/MSIE (\d)/i);
isIE=isIE?isIE[1]:undefined;
var isFF=/FireFox/i.test(navigator.userAgent);
//获取元素
var counter=document.getElementById("counter");
//鼠标滚轮事件
if(isIE<9) //传统浏览器使用MouseWheel事件
 counter.attachEvent("onmousewheel",function(){
  //计算鼠标滚轮滚动的距离
  //一格3行,每行40像素,所以除以120
  var v=event.wheelDelta/120;
  counter.innerHTML=counter.innerHTML*1+v;
  //阻止浏览器默认方法
  return false;
 });
else if(!isFF) //除火狐外的现代浏览器也使用MouseWheel事件
 counter.addEventListener("mousewheel",function(e){
  //计算鼠标滚轮滚动的距离
  var v=e.wheelDelta/120;
  counter.innerHTML=counter.innerHTML*1+v;
  //阻止浏览器默认方法
  e.preventDefault();
 },false);
else //奇葩的火狐使用DOMMouseScroll事件
 counter.addEventListener("DOMMouseScroll",function(e){
  //计算鼠标滚轮滚动的距离
  //一格是3行,但是要注意,这里和像素不同的是它是负值
  var v=-e.detail/3;
  counter.innerHTML=counter.innerHTML*1+v;
  //阻止浏览器默认方法
  e.preventDefault();
 },false);
</script>

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
Javascript写了一个清除“logo1_.exe”的杀毒工具(可扫描目录)
Feb 09 Javascript
检测jQuery.js是否已加载的判断代码
May 20 Javascript
jQuery实现可收缩展开的级联菜单实例代码
Nov 27 Javascript
ES6正则表达式扩展笔记
Jul 25 Javascript
ReactNative实现Toast的示例
Dec 31 Javascript
Vue 去除路径中的#号
Apr 19 Javascript
vue插件draggable实现拖拽移动图片顺序
Dec 01 Javascript
微信小程序登录态和检验注册过没的app.js写法
May 22 Javascript
vue中input的v-model清空操作
Sep 06 Javascript
解决layui动态添加的元素click等事件触发不了的问题
Sep 20 Javascript
Vue父组件监听子组件生命周期
Sep 03 Javascript
JavaScript实现网页跨年倒计时
Dec 02 Javascript
Css3制作变形与动画效果
Jul 24 #Javascript
四种参数传递的形式——URL,超链接,js,form表单
Jul 24 #Javascript
基于JS实现的倒计时程序实例
Jul 24 #Javascript
可以浮动某个物体的jquery控件用法实例
Jul 24 #Javascript
javascript比较两个日期相差天数的方法
Jul 24 #Javascript
JAVA四种基本排序方法实例总结
Jul 24 #Javascript
轻量级javascript 框架Backbone使用指南
Jul 24 #Javascript
You might like
菜鸟学PHP之Smarty入门
2007/01/04 PHP
php实现文件下载(支持中文文名)
2013/12/04 PHP
PHP读取大文件的类SplFileObject使用介绍
2014/04/09 PHP
php实现建立多层级目录的方法
2014/07/19 PHP
高质量PHP代码的50个实用技巧必备(下)
2016/01/22 PHP
jquery EasyUI的formatter格式化函数代码
2011/01/12 Javascript
js confirm()方法的使用方法实例
2013/07/13 Javascript
js特殊字符转义介绍
2013/11/05 Javascript
超链接的禁用属性Disabled使用示例
2014/07/31 Javascript
jQuery实现浮动层随浏览器滚动条滚动的方法
2015/09/22 Javascript
JS中dom0级事件和dom2级事件的区别介绍
2016/05/05 Javascript
JS实现关闭当前页而不弹出提示框的方法
2016/06/22 Javascript
详解Vue生命周期的示例
2017/03/10 Javascript
JsChart组件使用详解
2018/03/04 Javascript
iView框架问题整理小结
2018/10/16 Javascript
利用vue-i18n实现多语言切换效果的方法
2019/06/19 Javascript
js实现3D旋转相册
2020/08/02 Javascript
[04:55]完美世界副总裁蔡玮:DOTA2的自由、公平与信任
2013/12/18 DOTA
[57:29]Alliance vs KG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/17 DOTA
Python实现Linux的find命令实例分享
2017/06/04 Python
python+opencv实现动态物体识别
2018/01/09 Python
使用豆瓣源来安装python中的第三方库方法
2021/01/26 Python
Pytorch之扩充tensor的操作
2021/03/04 Python
css3和jquery实现的可折叠导航菜单适合放在手机网页的导航菜单
2014/09/02 HTML / CSS
Html5之自定义属性(data-,dataset)
2019/11/19 HTML / CSS
我的applet原先好好的, 一放到web server就会有问题,为什么?
2016/05/10 面试题
车间班组长的职责
2013/12/13 职场文书
通信研究生自荐信
2014/02/01 职场文书
小学评语大全
2014/04/22 职场文书
酒店七夕情人节活动策划方案
2014/08/24 职场文书
作风整顿剖析材料
2014/09/30 职场文书
2014年信息中心工作总结
2014/12/17 职场文书
导游词开场白
2015/01/31 职场文书
2015年共青团工作总结
2015/05/15 职场文书
学术会议开幕词
2016/03/03 职场文书
Nginx中使用Lua脚本与图片的缩略图处理的实现
2022/03/18 Servers