JavaScript 滾輪事件使用說明

來源:互聯網
上載者:User

不過遺憾的是各瀏覽器都不盡相同。

一) 事件名稱不相同
IE, KHTML(Safari, Chrome), Opera對應的事件名稱是 "mousewheel"。而 Gecko(Firefox, Netscape) 對應的事件名稱是 "DOMMouseScroll"。

二) 事件對象的屬性不一樣
有時我們需要知道使用者是向上滾了還是向下滾了。例如我們有一個響應滾動事件的函數: 複製代碼 代碼如下:function wheelHandle(e) {
if(e.wheelDelta) {// IE, KHTML, Opera
alert(e.wheelDelta > 0 ? '向上滾' : '向下滾');
} else { // Gecko
alert(e.detail < 0 ? '向上滾' : '向下滾');
}
}

IE, KHTML 支援 e.wheelDelta ,大於 0 為向上滾動,小於 0 為向下滾動。Gecko 支援 e.detail,小於 0 為向上滾動,大於 0 為向上滾動,跟前面的相反。而 Opera 比較牛,兩種都支援。
下面給出一個註冊滾輪事件的函數做參考: 複製代碼 代碼如下:/**
* 註冊滾輪事件函數
* @param element : 註冊的事件對象
* @param wheelHandle : 註冊事件函數
*/
function addScrollListener(element, wheelHandle) {
if(typeof element != 'object') return;
if(typeof wheelHandle != 'function') return;
// 監測瀏覽器
if(typeof arguments.callee.browser == 'undefined') {
var user = navigator.userAgent;
var b = {};
b.opera = user.indexOf("Opera") > -1 && typeof window.opera == "object";
b.khtml = (user.indexOf("KHTML") > -1 || user.indexOf("AppleWebKit") > -1 || user.indexOf("Konqueror") > -1) && !b.opera;
b.ie = user.indexOf("MSIE") > -1 && !b.opera;
b.gecko = user.indexOf("Gecko") > -1 && !b.khtml;
arguments.callee.browser = b;
}
if(element == window)
element = document;
if(arguments.callee.browser.ie)
element.attachEvent('onmousewheel', wheelHandle);
else
element.addEventListener(arguments.callee.browser.gecko ? 'DOMMouseScroll' : 'mousewheel', wheelHandle, false);
}

註冊一個監聽事件: 複製代碼 代碼如下:var display = document.getElementById('display');
function wheelHandle(e) {
if(e.wheelDelta) {// IE, KHTML, Opera
display.innerHTML = (e.wheelDelta > 0 ? '上' : '下');
} else { // Gecko
display.innerHTML = (e.detail < 0 ? '上' : '下');
}
}
addScrollListener(window, wheelHandle);

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.