javascript實(shí)現(xiàn)禁止鼠標(biāo)滾輪事件
平時(shí)我們兼容什么東西總是在調(diào)整低版本IE的兼容性,但是這回不是因?yàn)榈桶姹緸g覽器不給力。而是因?yàn)榛鸷o力過(guò)頭了,完全不顧其它瀏覽器的感受標(biāo)新立異了。除了火狐之外,所有的瀏覽器都可以使用MouseWheel事件來(lái)處理鼠標(biāo)滾輪的響應(yīng)。但是火狐卻偏偏不支持MouseWheel,而使用無(wú)厘頭的DOMMouseScroll,這玩意兒除了火狐以外其它瀏覽器都不兼容。也就是說(shuō),對(duì)于鼠標(biāo)滾輪事件的處理,火狐只能使用DOMMouseScroll。而非火狐則只能使用MouseWheel。這兩種事件實(shí)現(xiàn)的原理不同,他們處理的數(shù)據(jù)也不同。
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;
}
我們來(lái)看個(gè)完整的代碼
<!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>使用鼠標(biāo)滾輪調(diào)整數(shù)值大小</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");
//鼠標(biāo)滾輪事件
if(isIE<9) //傳統(tǒng)瀏覽器使用MouseWheel事件
counter.attachEvent("onmousewheel",function(){
//計(jì)算鼠標(biāo)滾輪滾動(dòng)的距離
//一格3行,每行40像素,所以除以120
var v=event.wheelDelta/120;
counter.innerHTML=counter.innerHTML*1+v;
//阻止瀏覽器默認(rèn)方法
return false;
});
else if(!isFF) //除火狐外的現(xiàn)代瀏覽器也使用MouseWheel事件
counter.addEventListener("mousewheel",function(e){
//計(jì)算鼠標(biāo)滾輪滾動(dòng)的距離
var v=e.wheelDelta/120;
counter.innerHTML=counter.innerHTML*1+v;
//阻止瀏覽器默認(rèn)方法
e.preventDefault();
},false);
else //奇葩的火狐使用DOMMouseScroll事件
counter.addEventListener("DOMMouseScroll",function(e){
//計(jì)算鼠標(biāo)滾輪滾動(dòng)的距離
//一格是3行,但是要注意,這里和像素不同的是它是負(fù)值
var v=-e.detail/3;
counter.innerHTML=counter.innerHTML*1+v;
//阻止瀏覽器默認(rèn)方法
e.preventDefault();
},false);
</script>
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- JS實(shí)現(xiàn)禁止高頻率連續(xù)點(diǎn)擊的方法【基于ES6語(yǔ)法】
- js禁止瀏覽器的回退事件
- js控制文本框禁止輸入特殊字符詳解
- JS實(shí)現(xiàn)禁止鼠標(biāo)右鍵的功能
- JS禁止查看網(wǎng)頁(yè)源代碼的實(shí)現(xiàn)方法
- JavaScript禁止用戶多次提交的兩種方法
- javascript禁止超鏈接跳轉(zhuǎn)的方法
- JavaScript如何禁止Backspace鍵
- JavaScript代碼實(shí)現(xiàn)禁止右鍵、禁選擇、禁粘貼、禁shift、禁ctrl、禁alt
- 深入探討JavaScript、JQuery屏蔽網(wǎng)頁(yè)鼠標(biāo)右鍵菜單及禁止選擇復(fù)制
- JS實(shí)現(xiàn)禁止用戶使用Ctrl+鼠標(biāo)滾輪縮放網(wǎng)頁(yè)的方法
相關(guān)文章
JS網(wǎng)頁(yè)圖片按比例自適應(yīng)縮放實(shí)現(xiàn)方法
這篇文章主要介紹了JS網(wǎng)頁(yè)圖片按比例自適應(yīng)縮放實(shí)現(xiàn)方法,有需要的朋友可以參考一下2014-01-01
uniapp開發(fā)小程序?qū)崿F(xiàn)滑動(dòng)頁(yè)面控制元素的顯示和隱藏效果
這篇文章主要介紹了uniapp開發(fā)小程序?qū)崿F(xiàn)滑動(dòng)頁(yè)面控制元素的顯示和隱藏效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
基于JavaScript實(shí)現(xiàn) 網(wǎng)頁(yè)切出 網(wǎng)站title變化代碼
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn) 網(wǎng)頁(yè)切出 網(wǎng)站title變化代碼的相關(guān)資料,需要的朋友可以參考下2016-04-04
簡(jiǎn)單實(shí)現(xiàn)JS倒計(jì)時(shí)效果
這篇文章主要教大家如何簡(jiǎn)單實(shí)現(xiàn)JS倒計(jì)時(shí)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
非html5實(shí)現(xiàn)js版彈球游戲示例代碼
彈球游戲,一般都是使用html5來(lái)實(shí)現(xiàn)的,其實(shí)不然,使用js也可以實(shí)現(xiàn)類似的效果,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下,希望對(duì)大家有所幫助2013-09-09
JS圖片懶加載的優(yōu)點(diǎn)及實(shí)現(xiàn)原理
這篇文章主要介紹了JS圖片懶加載的優(yōu)點(diǎn)及實(shí)現(xiàn)原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
地址欄傳遞中文參數(shù)亂碼在js里用escape轉(zhuǎn)碼
亂碼,頭大的一件事可以考慮轉(zhuǎn)碼方式不直接傳中文,在js里用escape轉(zhuǎn)碼,具體實(shí)現(xiàn)如下,有類似情況的朋友可以參考下2013-08-08

