<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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


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


    網站導航:
     
    主站蜘蛛池模板: 亚洲综合图色40p| 亚洲国产精品一区二区三区久久| 久久亚洲国产中v天仙www| 精品特级一级毛片免费观看| 亚洲日韩精品A∨片无码| 亚洲日韩精品射精日| 一区二区三区免费视频观看| 亚洲精品高清在线| 五月天婷婷精品免费视频| 亚洲片一区二区三区| 中文字幕在线视频免费| 亚洲国产另类久久久精品小说| 香蕉视频在线免费看| 国产无人区码卡二卡三卡免费| 亚洲精品国产肉丝袜久久| 成年黄网站色大免费全看| 亚洲av无码片区一区二区三区| 拨牐拨牐x8免费| 美女被免费网站在线视频免费| 亚洲人成电影在线播放| WWW免费视频在线观看播放| 亚洲Aⅴ无码专区在线观看q| 久久精品毛片免费观看| 久久综合久久综合亚洲| 国产一区二区三区在线免费| 99久久免费国产特黄| 亚洲福利视频网站| 国产男女猛烈无遮挡免费视频网站| 成人免费夜片在线观看| 亚洲专区在线视频| 成人免费看片又大又黄| 国产VA免费精品高清在线| 久久亚洲国产精品成人AV秋霞| 午夜dj免费在线观看| 久久成人18免费网站| 亚洲国产成人无码av在线播放| 波多野结衣视频在线免费观看| 日本免费一区二区三区四区五六区| 亚洲国产成人精品激情| 毛片免费观看视频| 亚洲一区二区三区免费|