HTML5中新添加了很多事件,但是由于他們的相容問題不是很理想,應用實戰性不是太強,是以在這裡基本省略,咱們隻分享應用廣泛相容不錯的事件,日後随着相容情況提升以後再陸續添加分享。今天為大家介紹的事件主要是觸摸事件:touchstart、touchmove和touchend。
一開始觸摸事件touchstart、touchmove和touchend是iOS版Safari浏覽器為了向開發人員傳達一些資訊新添加的事件。因為ios裝置既沒有滑鼠也沒有鍵盤,是以在為移動Safari浏覽器開發互動性網頁的時候,PC端的滑鼠和鍵盤事件是不夠用的。
在iPhone 3Gs釋出的時候,其自帶的移動Safari浏覽器就提供了一些與觸摸(touch)操作相關的新事件。随後,Android上的浏覽器也實作了相同的事件。觸摸事件(touch)會在使用者手指放在螢幕上面的時候、在螢幕上滑動的時候或者是從螢幕上移開的時候出發。下面具體說明:
touchstart事件:當手指觸摸螢幕時候觸發,即使已經有一個手指放在螢幕上也會觸發。
touchmove事件:當手指在螢幕上滑動的時候連續地觸發。在這個事件發生期間,調用preventDefault()事件可以阻止滾動。
touchend事件:當手指從螢幕上離開的時候觸發。
touchcancel事件:當系統停止跟蹤觸摸的時候觸發。關于這個事件的确切出發時間,文檔中并沒有具體說明,咱們隻能去猜測了。
上面的這些事件都會冒泡,也都可以取消。雖然這些觸摸事件沒有在DOM規範中定義,但是它們卻是以相容DOM的方式實作的。是以,每個觸摸事件的event對象都提供了在滑鼠實踐中常見的屬性:bubbles(起泡事件的類型)、cancelable(是否用 preventDefault() 方法可以取消與事件關聯的預設動作)、clientX(傳回當事件被觸發時,滑鼠指針的水準坐标)、clientY(傳回當事件觸發時,滑鼠指針的垂直坐标)、screenX(當某個事件被觸發時,滑鼠指針的水準坐标)和screenY(傳回當某個事件被觸發時,滑鼠指針的垂直坐标)。除了常見的DOM屬性,觸摸事件還包含下面三個用于跟蹤觸摸的屬性。
touches:表示目前跟蹤的觸摸操作的touch對象的數組。
targetTouches:特定于事件目标的Touch對象的數組。
changeTouches:表示自上次觸摸以來發生了什麼改變的Touch對象的數組。
每個Touch對象包含的屬性如下。
clientX:觸摸目标在視口中的x坐标。
clientY:觸摸目标在視口中的y坐标。
identifier:辨別觸摸的唯一ID。
pageX:觸摸目标在頁面中的x坐标。
pageY:觸摸目标在頁面中的y坐标。
screenX:觸摸目标在螢幕中的x坐标。
screenY:觸摸目标在螢幕中的y坐标。
target:觸目的DOM節點目标。
上面的屬性光這麼看,果然非常繁瑣,每個屬性說的都是那麼的細緻,隻有真刀實槍的來點小例子才能更加明白其中的奧妙。是以小例子如下。
function load (){
document.addEventListener('touchstart',touch, false);
document.addEventListener('touchmove',touch, false);
document.addEventListener('touchend',touch, false);
function touch (event){
var event = event || window.event;
var oInp = document.getElementById("inp");
switch(event.type){
case "touchstart":
oInp.innerHTML = "Touch started (" + event.touches[0].clientX + "," + event.touches[0].clientY + ")";
break;
case "touchend":
oInp.innerHTML = "<br>Touch end (" + event.changedTouches[0].clientX + "," + event.changedTouches[0].clientY + ")";
break;
case "touchmove":
event.preventDefault();
oInp.innerHTML = "<br>Touch moved (" + event.touches[0].clientX + "," + event.touches[0].clientY + ")";
break;
}
}
}
window.addEventListener('load',load, false);