javascript某标签的鼠标滚动事件取消效果或实现其他自定义效果
来源:互联网 发布:server2012网络连接 编辑:程序博客网 时间:2024/06/02 01:38
我看了下边的原文后,在jsp的boby标签上加个id="bb",然后在方法中加上
//给某标签的鼠标滚动事件取消效果或实现其他自定义效果
//其他自定义效果,在下边的原文里有例子
document.getElementById("bb").attachEvent("onmousewheel",function(){
return false;//这里必须返回false
});
以下是看的原文:
平时我们兼容什么东西总是在调整低版本IE的兼容性,但是这回不是因为低版本浏览器不给力。而是因为火狐给力过头了,完全不顾其它浏览器的感受标新立异了。除了火狐之外,所有的浏览器都可以使用MouseWheel事件来处理鼠标滚轮的响应。但是火狐却偏偏不支持MouseWheel,而使用无厘头的DOMMouseScroll,这玩意儿除了火狐以外其它浏览器都不兼容。也就是说,对于鼠标滚轮事件的处理,火狐只能使用DOMMouseScroll。而非火狐则只能使用MouseWheel。这两种事件实现的原理不同,他们处理的数据也不同。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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
;
}
我们来看个完整的代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<!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>
以上所述就是本文的全部内容了,希望大家能够喜欢。
阅读全文
0 0
- javascript某标签的鼠标滚动事件取消效果或实现其他自定义效果
- javascript实现的图片滚动效果,鼠标放上可停止
- JS自定义滚动条效果+鼠标滚轮事件
- ViewPager + Fragment 实现标签的滚动效果
- Java实现带有滚动效果的标签
- 自定义PickerView实现滚动选择器的效果
- 标签marquee实现滚动效果
- 鼠标滚动事件,侧边导航js效果
- JavaScript中通过鼠标事件实现模拟拖放效果
- 自定义ViewFlipper 实现滚动效果
- 自定义滚动条效果实现
- javascript实现图片滚动效果
- javascript实现图片滚动效果
- javascript+css 实现滚动效果
- 自定义标签实现分页效果
- JS特效:用鼠标事件实现图片的渐显效果
- DIV+CSS实现区域鼠标事件的动态效果
- HTML标签marquee实现滚动效果
- iOS 短信验证码倒计时按钮的实现
- Spring Boot添加JSP模板
- dom 事件对象中target与currentTarget区别
- HBase介绍、安装与应用案例
- shell 脚本编程学习(二) 变量,用户输入,参数
- javascript某标签的鼠标滚动事件取消效果或实现其他自定义效果
- max与min
- 利用git上传文件到远程仓库
- Mac 系统ReactNative环境搭建以及Node版本切换
- 开发工具
- 八皇后问题
- oracle导出sequence的SQL语句
- iOS FMDB数据库实现增删改查
- python数据类型(下)