移動端事件touchstart、touchmove、touchend

来源:http://www.cnblogs.com/liu-fei-fei/archive/2016/06/25/5616407.html
-Advertisement-
Play Games

關於這三個移動端的事件,詳細的資料網上一搜一大片,我就不浪費時間了 1.移動端長按事件 說明:通過定時器模擬長按事件,這個例子基於jQuery,【ele】是要長按的元素; 2.移動端上下左右滑動事件 說明:具體原理一搜一堆,這裡的具體例子,拷貝就能用;我的學習方式是,不管什麼原理之類的,先要做的就是 ...


關於這三個移動端的事件,詳細的資料網上一搜一大片,我就不浪費時間了

1.移動端長按事件

var timer = null;
$(ele).on('touchstart',function(){
    timer = setTimeout(function(){
        alert("我是長按事件!")
    },800);
});
$(ele).on('touchend',function(){
    clearTimeout(timer);
});

說明:通過定時器模擬長按事件,這個例子基於jQuery,【ele】是要長按的元素;

2.移動端上下左右滑動事件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=no">
    <title>touch</title>
</head>
<body>
<div id="touchLR">動起來</div>
<script>
// 左右滑動事件
var startX = 0, startY = 0;
function touchSatrtFunc(evt) {
    try
    {
        evt.preventDefault(); //阻止觸摸時瀏覽器的縮放、滾動條滾動等
        var touch = evt.touches[0]; //獲取第一個觸點
        var x = Number(touch.pageX); //頁面觸點X坐標
        var y = Number(touch.pageY); //頁面觸點Y坐標
        //記錄觸點初始位置
        startX = x;
        startY = y;
    }
    catch (e) {
        alert('touchSatrtFunc:' + e.message);
    }
}
function touchMoveFunc(evt) {
    try
    {
        evt.preventDefault(); //阻止觸摸時瀏覽器的縮放、滾動條滾動等
        var touch = evt.touches[0]; //獲取第一個觸點
        var x = Number(touch.pageX); //頁面觸點X坐標
        var y = Number(touch.pageY); //頁面觸點Y坐標

        var text;
        //判斷滑動左右方向
        if (x - startX>=30) {
            text = '向右滑動';
            document.getElementById('touchLR').innerHTML = text;
        }else if(x - startX<=-30){
            text = '向左滑動';
            document.getElementById('touchLR').innerHTML = text;
        }
        //判斷滑動上下方向
        if (y - startY>=30) {
            text = '向下滑動';
            document.getElementById('touchLR').innerHTML = text;
        }else if(y - startY<=-30){
            text = '向上滑動';
            document.getElementById('touchLR').innerHTML = text;
        }
    }
    catch (e) {
        alert('touchMoveFunc:' + e.message);
    }
}
function bindEvent() {
    document.addEventListener('touchstart', touchSatrtFunc, false);
    document.addEventListener('touchmove', touchMoveFunc, false);
}
bindEvent();
</script>
</body>
</html>

說明:具體原理一搜一堆,這裡的具體例子,拷貝就能用;我的學習方式是,不管什麼原理之類的,先要做的就是把需求弄出來,在捉摸原理;事半功倍


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • × 目錄 [1]邏輯非 [2]邏輯與 [3]邏輯或 前面的話 邏輯運算符對操作數進行布爾運算,經常和關係運算符一樣配合使用。邏輯運算符將多個關係表達式組合起來組成一個更複雜的表達式。邏輯運算符分為邏輯非'!'、邏輯與'&&'、邏輯或'||'3種,本文將介紹這三種邏輯運算符 邏輯非 邏輯非操作符由一個 ...
  • HTML經過10多年的發展,其元素經歷了廢棄與不斷重新定義的過程。為了更好的處理現在的互聯網應用,HTML5新增了圖形繪製、多媒體播放、頁面結構、應用程式存儲、網路工作等新元素。http://hovertree.com/menu/html5/ 圖形繪製新元素 標簽描述 <canvas> 標簽定義圖形 ...
  • HTML5簡介 HTML5是HTML的最新修訂標準。2014年10月29日,萬維網聯盟(W3C)宣佈,經過8年的努力,HTML5標準規範制定完成。 HTML5的設計目的是在移動設備上使用多媒體。 HTML5簡單易學。 http://hovertree.com/menu/html5/ 什麼是HTML5 ...
  • × 目錄 [1]定義 [2]應用場景 [3]轉為布爾[4]實例方法 前面的話 布爾值Boolean類型可能是三種包裝對象Number、String和Boolean中最簡單的一種。Number和String對象擁有大量的實例屬性和方法,Boolean卻很少。從某種意義上說,為電腦設計程式就是與布爾值 ...
  • 1、HTML5不支持或不贊成使用的標簽 <acronym>——定義只取首字母的縮寫,HTML5 不支持。使用<abbr>定義縮寫代替,其中title 屬性可用於在滑鼠指針移動到元素上時顯示出縮寫的完整版本,堅持寫上title,這樣對瀏覽器和搜索引擎都比較友好。 <applet>——定義嵌入的 app ...
  • 在不同瀏覽器查看代碼效果可謂是家常便飯,所以用不同快捷鍵打開相應瀏覽器可以大大提高工作效率。工欲善其事,必先利其器啊,沒設置看文章吧,非常簡單。 ...
  • CSS樣式規範 1.類選擇器 2.標簽選擇器 3.id選擇器 4.CSS樣式的子選擇器 類選擇器 1.必背的固定結構,成為CSS樣式標記。所有的樣式都可以寫成CSS樣式的標記中 <style type="text/css"> </style> 2. type=“text/css” 意思是聲明這個標記 ...
  • 通過javascript進行UTF 8編碼 javascript的字元集: javascript程式是使用 字元集編寫的。 是`ASCII Latin 1 ECMAScript3 Unicode2.1 ECMAScript5 Unicode3`及後續版本。所以,我們編寫出來的javascript程式 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...