監聽鼠標上下滾動事件


js如何判斷滾輪的上下滾動,我們應該都見到過這種效果,用鼠標滾輪實現某個表單內的數字向上滾動就增加,向下滾動就減少的操作,這種效果是通過 js對鼠標滾輪的事件監聽來實現的。今天簡單的研究了一下如何使用javascript來判斷鼠標是向上滾動還是向下滾動,簡要分享。

首先,不得不說一下,因為不同的瀏覽器有 不同的滾輪事件。主要是有兩種,onmousewheel(firefox不支持)和DOMMouseScroll(只有firefox支持),關於這兩 個事件這里不做詳述,想要了解的朋友請移步:鼠標滾輪(mousewheel)和DOMMouseScroll事件,所以在這個過程中需要添加事件監聽, 代碼如下:兼容firefox采用addEventListener監聽。

/*注冊事件*/ 
if(document.addEventListener){ 
    document.addEventListener('DOMMouseScroll',scrollFunc,false); 
}//W3C 
window.onmousewheel=document.onmousewheel=scrollFunc;//IE/Opera/Chrome 

  另外判斷滾輪向上或向下滾動在瀏覽器中也要考慮兼容性,現在五大瀏覽器(IE、Opera、 Safari、Firefox、Chrome)中Firefox 使用detail,其余四類使用wheelDelta;兩者只在取值上不一致,代表含義卻是一致的,detail只取±3,wheelDelta只 取±120,其中正數表示為向上,負數表示向下。
 
具體的示例代碼如下所示:

<label for="wheelDelta">滾動值:</label>(IE/Opera)<input type="text" id="wheelDelta"/> 
<label for="detail">滾動值:(Firefox)</label><input type="text" id="detail"/> 
<script type="text/javascript"> 
var scrollFunc=function(e){ 
    ee=e || window.event; 
    var t1=document.getElementById("wheelDelta"); 
    var t2=document.getElementById("detail"); 
    if(e.wheelDelta){//IE/Opera/Chrome 
        t1.value=e.wheelDelta; 
    }else if(e.detail){//Firefox 
        t2.value=e.detail; 
    } 
} 
/*注冊事件*/ 
if(document.addEventListener){ 
    document.addEventListener('DOMMouseScroll',scrollFunc,false); 
}//W3C 
window.onmousewheel=document.onmousewheel=scrollFunc;//IE/Opera/Chrome 
</script> 

  

通過運行上述代碼我們可以得出以下結果:

在非firefox瀏覽器中,滾輪向上滾動返回的數值是120,向下滾動返回-120
 
而在firefox瀏覽器中,滾輪向上滾動返回的數值是-3,向下滾動返回3

 
代碼部分如下,e.wheelDelta是判斷是否為非firefox瀏覽器,e.detail為firefox瀏覽器

if(e.wheelDelta){//IE/Opera/Chrome 
    t1.value=e.wheelDelta; 
}else if(e.detail){//Firefox 
    t2.value=e.detail; 
} 

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM