主頁 > 知識(shí)庫 > 整理HTML5移動(dòng)端開發(fā)的常用觸摸事件

整理HTML5移動(dòng)端開發(fā)的常用觸摸事件

熱門標(biāo)簽:杭州營(yíng)銷電銷機(jī)器人供應(yīng)商 聯(lián)通400電話申請(qǐng) 飛亞外呼系統(tǒng) 貸款電銷人工和機(jī)器人哪個(gè)好 百應(yīng)電銷機(jī)器人產(chǎn)業(yè) 電視購物電銷外呼系統(tǒng) 高德地圖標(biāo)注賓館位置 西寧智能外呼系統(tǒng)加盟 電話機(jī)器人如何

HTML5中新添加了很多事件,但是由于他們的兼容問題不是很理想,應(yīng)用實(shí)戰(zhàn)性不是太強(qiáng),所以在這里基本省略,咱們只分享應(yīng)用廣泛兼容不錯(cuò)的事件,日后隨著兼容情況提升以后再陸續(xù)添加分享。今天為大家介紹的事件主要是觸摸事件:touchstart、touchmove和touchend。

  一開始觸摸事件touchstart、touchmove和touchend是iOs版Safari瀏覽器為了向開發(fā)人員傳達(dá)一些信息新添加的事件。因?yàn)閕Os設(shè)備既沒有鼠標(biāo)也沒有鍵盤,所以在為移動(dòng)Safari瀏覽器開發(fā)交互性網(wǎng)頁的時(shí)候,PC端的鼠標(biāo)和鍵盤事件是不夠用的。

  在iPhone 3Gs發(fā)布的時(shí)候,其自帶的移動(dòng)Safari瀏覽器就提供了一些與觸摸(touch)操作相關(guān)的新事件。隨后,Android上的瀏覽器也實(shí)現(xiàn)了相同的事件。觸摸事件(touch)會(huì)在用戶手指放在屏幕上面的時(shí)候、在屏幕上滑動(dòng)的時(shí)候或者是從屏幕上移開的時(shí)候出發(fā)。下面具體說明:

  touchstart事件:當(dāng)手指觸摸屏幕時(shí)候觸發(fā),即使已經(jīng)有一個(gè)手指放在屏幕上也會(huì)觸發(fā)。

  touchmove事件:當(dāng)手指在屏幕上滑動(dòng)的時(shí)候連續(xù)地觸發(fā)。在這個(gè)事件發(fā)生期間,調(diào)用preventDefault()事件可以阻止?jié)L動(dòng)。

  touchend事件:當(dāng)手指從屏幕上離開的時(shí)候觸發(fā)。

  touchcancel事件:當(dāng)系統(tǒng)停止跟蹤觸摸的時(shí)候觸發(fā)。關(guān)于這個(gè)事件的確切出發(fā)時(shí)間,文檔中并沒有具體說明,咱們只能去猜測(cè)了。

  上面的這些事件都會(huì)冒泡,也都可以取消。雖然這些觸摸事件沒有在DOM規(guī)范中定義,但是它們卻是以兼容DOM的方式實(shí)現(xiàn)的。所以,每個(gè)觸摸事件的event對(duì)象都提供了在鼠標(biāo)實(shí)踐中常見的屬性:bubbles(起泡事件的類型)、cancelable(是否用 preventDefault() 方法可以取消與事件關(guān)聯(lián)的默認(rèn)動(dòng)作)、clientX(返回當(dāng)事件被觸發(fā)時(shí),鼠標(biāo)指針的水平坐標(biāo))、clientY(返回當(dāng)事件觸發(fā)時(shí),鼠標(biāo)指針的垂直坐標(biāo))、screenX(當(dāng)某個(gè)事件被觸發(fā)時(shí),鼠標(biāo)指針的水平坐標(biāo))和screenY(返回當(dāng)某個(gè)事件被觸發(fā)時(shí),鼠標(biāo)指針的垂直坐標(biāo))。除了常見的DOM屬性,觸摸事件還包含下面三個(gè)用于跟蹤觸摸的屬性。


  touches:表示當(dāng)前跟蹤的觸摸操作的touch對(duì)象的數(shù)組。

  targetTouches:特定于事件目標(biāo)的Touch對(duì)象的數(shù)組。

  changeTouches:表示自上次觸摸以來發(fā)生了什么改變的Touch對(duì)象的數(shù)組。


每個(gè)Touch對(duì)象包含的屬性如下。

  clientX:觸摸目標(biāo)在視口中的x坐標(biāo)。

  clientY:觸摸目標(biāo)在視口中的y坐標(biāo)。

  identifier:標(biāo)識(shí)觸摸的唯一ID。

  pageX:觸摸目標(biāo)在頁面中的x坐標(biāo)。

  pageY:觸摸目標(biāo)在頁面中的y坐標(biāo)。

  screenX:觸摸目標(biāo)在屏幕中的x坐標(biāo)。

  screenY:觸摸目標(biāo)在屏幕中的y坐標(biāo)。

  target:觸目的DOM節(jié)點(diǎn)目標(biāo)。

每個(gè)觸摸點(diǎn)由包含了如下觸摸信息(常用):

identifier:一個(gè)數(shù)值,唯一標(biāo)識(shí)觸摸會(huì)話(touch session)中的當(dāng)前手指。一般為從0開始的流水號(hào)(android4.1,uc)

target:DOM元素,是動(dòng)作所針對(duì)的目標(biāo)。

pageX/pageX/clientX/clientY/screenX/screenY:一個(gè)數(shù)值,動(dòng)作在屏幕上發(fā)生的位置(page包含滾動(dòng)距離,client不包含滾動(dòng)距離,screen則以屏幕為基準(zhǔn))?!?/p>

radiusX/radiusY/rotationAngle:畫出大約相當(dāng)于手指形狀的橢圓形,分別為橢圓形的兩個(gè)半徑和旋轉(zhuǎn)角度。初步測(cè)試瀏覽器不支持,好在功能不常用,歡迎大家反饋。

JavaScript操作小例子:

JavaScript Code復(fù)制內(nèi)容到剪貼板
  1. var obj = document.getElementByIdx_x('id');   
  2. obj.addEventListener('touchmove'function(event) {   
  3.      // 如果這個(gè)元素的位置內(nèi)只有一個(gè)手指的話   
  4.     if (event.targetTouches.length == 1) {   
  5.      event.preventDefault();// 阻止瀏覽器默認(rèn)事件,重要    
  6.         var touch = event.targetTouches[0];   
  7.         // 把元素放在手指所在的位置   
  8.         obj.style.left = touch.pageX-50 + 'px';   
  9.         obj.style.top = touch.pageY-50 + 'px';   
  10.         }   
  11. }, false);  

標(biāo)簽:邯鄲 玉溪 安慶 晉中 煙臺(tái) 內(nèi)蒙古 撫州 牡丹江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《整理HTML5移動(dòng)端開發(fā)的常用觸摸事件》,本文關(guān)鍵詞  整理,HTML5,移動(dòng),端,開發(fā),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《整理HTML5移動(dòng)端開發(fā)的常用觸摸事件》相關(guān)的同類信息!
  • 本頁收集關(guān)于整理HTML5移動(dòng)端開發(fā)的常用觸摸事件的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章