在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/HTML/ 在阻止瀏覽器默認(rèn)行為時(shí),的問題

在阻止瀏覽器默認(rèn)行為時(shí),的問題

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>無標(biāo)題文檔</title>
<style>
#div1 {width: 100px; height: 100px; background: red;}
</style>
<script>
/*
鼠標(biāo)滾輪事件
*/
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 所觸發(fā)的默認(rèn)行為
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>
問題:在阻止瀏覽器默認(rèn)行為時(shí),使用了return false;ev.preventDefault();為什么只組織了瀏覽器的滾動(dòng)的默認(rèn)行為呢?其他的右鍵,彈出環(huán)境菜單等依然是有瀏覽器的默認(rèn)行為的?

回答
編輯回答
雅痞

你僅僅是對(duì) DOMMouseScroll 做了處理。
右鍵應(yīng)該處理 document.oncontextmenu, 或者(object.addEventListener("contextmenu", thisScript);) 。

2017年6月21日 20:18
編輯回答
綰青絲

謝邀!
首先您要理解event對(duì)象是什么?
event對(duì)象是事件發(fā)生之后,生成的一個(gè)事件對(duì)象,然后作為參數(shù)傳給相應(yīng)的函數(shù)。
請(qǐng)注意:event對(duì)象只在事件發(fā)生的過程中有效,event代表的是事件的狀態(tài)

接下來再理解下preventDefault()是什么?
preventDefault()用于取消瀏覽器對(duì)當(dāng)前事件的默認(rèn)行為,當(dāng)前事件的默認(rèn)行為,當(dāng)前事件的默認(rèn)行為,重要的事情說三遍。
請(qǐng)注意:只要在事件的傳播過程中(捕獲階段、目標(biāo)階段、冒泡階段都可以),使用了preventDefault方法,該事件的默認(rèn)方法就不會(huì)執(zhí)行。

廢話不說了,返回到您的問題,您這邊僅僅是阻止了DOMMouseScroll的默認(rèn)行為,并沒有對(duì)右鍵事件做任何處理,所以不會(huì)生效。

2017年8月9日 19:41