觸屏中的JavaScript事件

來源:互聯網
上載者:User

轉自:http://wangyong31893189.iteye.com/blog/1337023

一、觸摸事件
ontouchstart
ontouchmove
ontouchend
ontouchcancel

目前移動端瀏覽器均支援這4個觸摸事件,包括IE。由於觸屏也支援MouseEvent,因此他們的順序是需要注意的:touchstart → mouseover → mousemove → mousedown → mouseup → click1
 /**
* onTouchEvent
*/
var div = document.getElementById("div");
//touchstart類似mousedown
div.ontouchstart = function(e){
//事件的touches屬性是一個數組,其中一個元素代表同一時刻的一個觸控點,從而可以通過touches擷取多點觸控的每個觸控點
//由於我們只有一點觸控,所以直接指向[0]
var touch = e.touches[0];
//擷取當前觸控點的座標,等同於MouseEvent事件的clientX/clientY
var x = touch.clientX;
var y = touch.clientY;
};
//touchmove類似mousemove
div.ontouchmove = function(e){
//可為touchstart、touchmove事件加上preventDefault從而阻止觸摸時瀏覽器的縮放、捲軸滾動等
e.preventDefault();
};
//touchend類似mouseup
div.ontouchup = function(e){
//nothing to do
};
二、手勢事件

       手勢是指利用多點觸控進行旋轉、展開等操作,例片、網頁的放大、旋轉。需要兩個或以上的手指同時觸摸時才會觸發手勢事件。關於縮放我們需要注意的一點是元素的位置座標:我們通常使用offsetX、getBoundingClientRect等方法擷取元素的位置座標,但在手機瀏覽器中頁面經常會在使用中被縮放,那縮放後的元素座標會改變嗎?答案是有所差異。用一個情景來說明這個問題:頁面A載入完成後,JavaScript擷取到該元素在document中的座標為(100,100),接著使用者放大了頁面,此時用JavaScript再次輸出元素座標,依然還是(100,100),但該元素在螢幕上的響應地區會根據縮放比例產生位移。你可以開啟那個打磚塊遊戲demo,等頁面完全載入完成後,再放大,此時你會發現即使手指觸摸在“touch
here”地區外部,也可以控制到球板,因為地區發生了位移。除非頁面重新整理或者恢複縮放,否則位移量將一直存在。1
/**
* onGestureEvent
*/
var div = document.getElementById("div");
div.ongesturechange = function(e){
//scale代表手勢產生的縮放比例,小於1是縮小,大於1是放大,原始為1
var scale = e.scale;
//rotation代表旋轉手勢的角度,值區間[0,360],正值順時針旋轉,負值逆時針
var angle = e.rotation;
};
三、重力感應

       
重力感應較簡單,只需要為body節點添加onorientationchange事件即可。在此事件中由window.orientation屬性得到代表當前手機方向的數值。window.orientation的值列表如下:
0:與頁面首次載入時的方向一致
-90:相對原始方向順時針轉了90°
180:轉了180°
90:逆時針轉了90°據我測試,Android2.1尚未支援重力感應。以上即目前的觸屏事件,這些事件尚未併入標準,但已被廣泛使用。本人Android2.1,未在其他環境下測試。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.