欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript 滾輪事件使用說明

 更新時間:2010年03月07日 14:41:24   作者:  
用過 Google 地圖的人可能都很熟悉,通過滾動滾輪可以對地圖進行縮放,非常地方便。適當?shù)厥褂脻L輪事件可以帶來不錯的用戶體驗。
不過遺憾的是各瀏覽器都不盡相同。

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

二) 事件對象的屬性不一樣
有時我們需要知道用戶是向上滾了還是向下滾了。例如我們有一個響應(yīng)滾動事件的函數(shù):
復制代碼 代碼如下:

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 比較牛,兩種都支持。
下面給出一個注冊滾輪事件的函數(shù)做參考:
復制代碼 代碼如下:

/**
* 注冊滾輪事件函數(shù)
* @param element : 注冊的事件對象
* @param wheelHandle : 注冊事件函數(shù)
*/
function addScrollListener(element, wheelHandle) {
if(typeof element != 'object') return;
if(typeof wheelHandle != 'function') return;
// 監(jiān)測瀏覽器
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);
}

注冊一個監(jiān)聽事件:
復制代碼 代碼如下:

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);

相關(guān)文章

  • js控制表單不能輸入空格的小例子

    js控制表單不能輸入空格的小例子

    這篇文章主要介紹了js控制表單不能輸入空格的小例子,有需要的朋友可以參考一下
    2013-11-11
  • 詳解js實現(xiàn)線段交點的三種算法

    詳解js實現(xiàn)線段交點的三種算法

    下面小編就最近學會的一些”求線段交點”的算法說一說, 希望對大家有所幫助?!扒缶€段交點”是一種非常基礎(chǔ)的幾何計算, 在很多游戲中都會被使用到。有需要的可以參考學習
    2016-08-08
  • 淺談Webpack是如何打包CommonJS的

    淺談Webpack是如何打包CommonJS的

    CommonJS是Node中的一種模塊化規(guī)范,本文主要介紹了Webpack是如何打包CJS的,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • javascript實現(xiàn)隨時變化著的背景顏色

    javascript實現(xiàn)隨時變化著的背景顏色

    這篇文章主要介紹了javascript實現(xiàn)隨時變化著的背景顏色的方法,非常的簡單實用,有需要的小伙伴可以直接拿走。
    2015-04-04
  • js控制臺報錯Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)的解決

    js控制臺報錯Uncaught TypeError: Cannot read p

    本文主要介紹了js控制臺報錯Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • javascript 顯示全局變量與隱式全局變量的區(qū)別

    javascript 顯示全局變量與隱式全局變量的區(qū)別

    這篇文章主要介紹了javascript 顯示全局變量與隱式全局變量的區(qū)別,需要的朋友可以參考下
    2017-02-02
  • HTML5之WebSocket入門3 -通信模型socket.io

    HTML5之WebSocket入門3 -通信模型socket.io

    socket.io能為程序員提供客戶端和服務(wù)端一致的編程體驗,socket.io支持任何的瀏覽器,任何的Mobile設(shè)備。下面通過本篇文章給大家講解HTML5之WebSocket入門3 -通信模型socket.io,需要的朋友可以參考下
    2015-08-08
  • JavaScript中this的用法及this在不同應(yīng)用場景的作用解析

    JavaScript中this的用法及this在不同應(yīng)用場景的作用解析

    由于其運行期綁定的特性,JavaScript 中的 this 含義要豐富得多,它可以是全局對象、當前對象或者任意對象,這完全取決于函數(shù)的調(diào)用方式,這篇文章主要給大家介紹了JavaScript中this的用法及this在不同應(yīng)用場景的作用解析,一起看看吧
    2017-04-04
  • javascript 二進制運算技巧解析

    javascript 二進制運算技巧解析

    javascript 中的二進制運算的一些技巧,曬出來和你們分享一下,希望可以幫助你們
    2012-11-11
  • 用JS實現(xiàn)的一個include函數(shù)

    用JS實現(xiàn)的一個include函數(shù)

    用JS實現(xiàn)的一個include函數(shù)...
    2007-07-07

最新評論