<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>无标题文档</title>
<style>
#div1 {width: 100px; height: 100px; background: red;}
</style>
<script>
/*
鼠标滚轮事件
*/
window.onload = function() {
var oDiv = document.getElementById('div1');
/*
ie/chrome : onmousewheel
event.wheelDelta
上:120
下:-120
firefox : DOMMouseScroll 必须用addEventListener
event.detail
上:-3
下:3
return false阻止的是 obj.on事件名称=fn 所触发的默认行为
addEventListener绑定的事件需要通过event下面的preventDefault();
*/
oDiv.onmousewheel = fn;
if (oDiv.addEventListener) {
oDiv.addEventListener('DOMMouseScroll', fn, false);
}
//alert(2);
function fn(ev) {
//alert(1);
var ev = ev || event;
//alert( ev.wheelDelta );
//alert(ev.detail)
var b = true;
if (ev.wheelDelta) {
b = ev.wheelDelta > 0 ? true : false;
} else {
b = ev.detail < 0 ? true : false;
}
//alert(b);
if ( b ) {
this.style.height = this.offsetHeight - 10 + 'px';
} else {
this.style.height = this.offsetHeight + 10 + 'px';
}
if (ev.preventDefault) {
ev.preventDefault();
}
return false;
}
}
</script>
</head>
<body style="height: 2000px;"> <div id="div1"></div> </body> </html>
问题:在阻止浏览器默认行为时,使用了return false;ev.preventDefault();为什么只组织了浏览器的滚动的默认行为呢?其他的右键,弹出环境菜单等依然是有浏览器的默认行为的?
谢邀!
首先您要理解
event对象是什么?
event对象是事件发生之后,生成的一个事件对象,然后作为参数传给相应的函数。
请注意:
event对象只在事件发生的过程中有效,event代表的是事件的状态
;接下来再理解下
preventDefault()是什么?
preventDefault()用于取消浏览器对
当前事件的默认行为,当前事件的默认行为,当前事件的默认行为,重要的事情说三遍
。请注意:
只要在事件的传播过程中(捕获阶段、目标阶段、冒泡阶段都可以),使用了preventDefault方法,该事件的默认方法就不会执行。
废话不说了,返回到您的问题,您这边仅仅是阻止了DOMMouseScroll的默认行为,并没有对右键事件做任何处理,所以不会生效。