tbwshc

          通過 JavaScript 獲取頁面上的鼠標位置

          用 JS 計算鼠標在頁面上的位置并非難事, 只要把握好各瀏覽器的區別就可以輕易算出鼠標位置. (這是 DEMO)

          視窗 (瀏覽器可視窗口) 就像是頁面上的掩板開了一個洞. 滾動條可以改變頁面和視窗之間的偏移量, 從而可以通過視窗看到頁面的各個位置.
          鼠標在頁面上的位置 = 頁面和視窗之間的偏移量 + 鼠標在視窗中的位置

          圖中的 cursorX 和 cursorY 分別是鼠標在視窗中的橫向和縱向位置, scrollY 是tb頁面和視窗之間的縱向距離. 當然, 當視窗寬度小于頁面寬度的時候, 還會存在 scrollX. 那么鼠標在頁面上的位置就是: (scrollX+cursorX, scrollY+cursorY)

          IE 以外的瀏覽器 (本人測試過 Firefox 3.6, Opera 10.10, Chrome 4.1 和 Safari 4.0.4) 均可以通過 pageXOffset 和 pageYOffset 來獲取頁面和視窗間的橫縱距離. 但 IE (本人測試過 IE6, IE7, IE8) 只能通過滾動位移來獲取頁面和視窗間的距離, 并存在一到兩個像素的偏離.

          以下是獲取鼠標在頁面上位置的代碼實現. (這是 DEMO)

          /**
           * 獲取鼠標在頁面上的位置
           * @param ev		觸發的事件
           * @return			x:鼠標在頁面上的橫向位置, y:鼠標在頁面上的縱向位置
           */
          function getMousePoint(ev) {
          	// 定義鼠標在視窗中的位置
          	var point = {
          		x:0,
          		y:0
          	};
           
          	// 如果瀏覽器支持 pageYOffset, 通過 pageXOffset 和 pageYOffset 獲取頁面和視窗之間的距離
          	if(typeof window.pageYOffset != 'undefined') {
          		point.x = window.pageXOffset;
          		point.y = window.pageYOffset;
          	}
          	// 如果瀏覽器支持 compatMode, 并且指定了 DOCTYPE, 通過 documentElement 獲取滾動距離作為頁面和視窗間的距離
          	// IE 中, 當頁面指定 DOCTYPE, compatMode 的值是 CSS1Compat, 否則 compatMode 的值是 BackCompat
          	else if(typeof document.compatMode != 'undefined' && document.compatMode != 'BackCompat') {
          		point.x = document.documentElement.scrollLeft;
          		point.y = document.documentElement.scrollTop;
          	}
          	// 如果瀏覽器支持 document.body, 可以通過 document.body 來獲取滾動高度
          	else if(typeof document.body != 'undefined') {
          		point.x = document.body.scrollLeft;
          		point.y = document.body.scrollTop;
          	}
           
          	// 加上鼠標在視窗中的位置
          	point.x += ev.clientX;
          	point.y += ev.clientY;
           
          	// 返回鼠標在視窗中的位置
          	return point;
          }

          記得以前我寫過一個減速滾動置頂的 JavaScript 方法, 也是通過計算視窗和頁面高度來實現的, 其計算方法與本文的方法不同小異, 也可以搬過來用.

          這幾個月來, 專注前端項目的開發, 也算小有收獲, 最近我會將一些積累作成文章分享于眾. 以此作為鋪墊, 由淺入深, 希望可以帶出一些有用的內容.

          posted on 2012-07-04 13:15 chen11-1 閱讀(182) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 广宁县| 怀柔区| 绥宁县| 确山县| 靖安县| 岗巴县| 伊春市| 罗源县| 镇远县| 曲阜市| 腾冲县| 安新县| 怀安县| 金堂县| 凤凰县| 峡江县| 福鼎市| 新建县| 东乌珠穆沁旗| 子长县| 惠东县| 邢台市| 镶黄旗| 南木林县| 长垣县| 静海县| 汕头市| 大宁县| 来凤县| 密山市| 县级市| 清河县| 蓝山县| 东乡| 辽阳市| 金湖县| 新野县| 民丰县| 玉环县| 浠水县| 栾川县|