在阻止浏览器默认行为时,的问题

<!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();为什么只组织了浏览器的滚动的默认行为呢?其他的右键,弹出环境菜单等依然是有浏览器的默认行为的?

阅读 2.3k
2 个回答

谢邀!
首先您要理解event对象是什么?
event对象是事件发生之后,生成的一个事件对象,然后作为参数传给相应的函数。
请注意:event对象只在事件发生的过程中有效,event代表的是事件的状态

接下来再理解下preventDefault()是什么?
preventDefault()用于取消浏览器对当前事件的默认行为,当前事件的默认行为,当前事件的默认行为,重要的事情说三遍
请注意:只要在事件的传播过程中(捕获阶段、目标阶段、冒泡阶段都可以),使用了preventDefault方法,该事件的默认方法就不会执行。

废话不说了,返回到您的问题,您这边仅仅是阻止了DOMMouseScroll的默认行为,并没有对右键事件做任何处理,所以不会生效。

你仅仅是对 DOMMouseScroll 做了处理。
右键应该处理 document.oncontextmenu, 或者(object.addEventListener("contextmenu", thisScript);) 。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题