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 閱讀(183) 評論(0)  編輯  收藏


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


          網站導航:
           

          My Links

          Blog Stats

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          新聞檔案

          tbw淘寶商城-首頁

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 牙克石市| 观塘区| 隆子县| 绥芬河市| 宜章县| 新乡县| 津南区| 增城市| 腾冲县| 绿春县| 榆社县| 满洲里市| 柳河县| 龙江县| 高邮市| 奈曼旗| 社会| 北京市| 澄江县| 铜梁县| 哈尔滨市| 镇宁| 南江县| 万安县| 西乌| 怀集县| 抚顺县| 尼玛县| 福建省| 玉屏| 丹阳市| 陆川县| 石林| 沂源县| 凭祥市| 中卫市| 高阳县| 喜德县| 北流市| 禹州市| 阜阳市|