当前位置: 首页 > article >正文

判断手机屏幕上的横向滑动(左滑和右滑)

在JavaScript中,你可以通过监听触摸事件(touch events)来判断用户在手机屏幕上的横向滑动方向。以下是实现方法:

基本实现方案

let touchStartX = 0;
let touchEndX = 0;function handleTouchStart(event) {touchStartX = event.changedTouches[0].screenX;
}function handleTouchEnd(event) {touchEndX = event.changedTouches[0].screenX;handleSwipe();
}function handleSwipe() {const threshold = 50; // 最小滑动距离阈值const diffX = touchEndX - touchStartX;if (Math.abs(diffX) > threshold) {if (diffX > 0) {console.log("向右滑动");// 执行右滑操作} else {console.log("向左滑动");// 执行左滑操作}}
}// 添加事件监听
const element = document.getElementById('swipe-area');
element.addEventListener('touchstart', handleTouchStart, false);
element.addEventListener('touchend', handleTouchEnd, false);

更完善的实现(包含滑动速度检测)

let touchStartX = 0;
let touchStartTime = 0;const element = document.getElementById('swipe-area');element.addEventListener('touchstart', (e) => {touchStartX = e.touches[0].clientX;touchStartTime = Date.now();
}, false);element.addEventListener('touchmove', (e) => {e.preventDefault(); // 阻止默认行为,避免页面滚动
}, { passive: false });element.addEventListener('touchend', (e) => {const touchEndX = e.changedTouches[0].clientX;const touchEndTime = Date.now();const diffX = touchEndX - touchStartX;const duration = touchEndTime - touchStartTime;const velocity = Math.abs(diffX) / duration; // 计算滑动速度const threshold = 50; // 最小滑动距离const minVelocity = 0.3; // 最小滑动速度(像素/毫秒)if (Math.abs(diffX) > threshold && velocity > minVelocity) {if (diffX > 0) {console.log("向右滑动");// 执行右滑操作} else {console.log("向左滑动");// 执行左滑操作}}
}, false);

React 组件实现示例

import React, { useRef } from 'react';const SwipeDetector = () => {const touchStartX = useRef(0);const touchStartTime = useRef(0);const handleTouchStart = (e) => {touchStartX.current = e.touches[0].clientX;touchStartTime.current = Date.now();};const handleTouchEnd = (e) => {const touchEndX = e.changedTouches[0].clientX;const touchEndTime = Date.now();const diffX = touchEndX - touchStartX.current;const duration = touchEndTime - touchStartTime.current;const velocity = Math.abs(diffX) / duration;const threshold = 50;const minVelocity = 0.3;if (Math.abs(diffX) > threshold && velocity > minVelocity) {if (diffX > 0) {console.log("向右滑动");// 执行右滑操作} else {console.log("向左滑动");// 执行左滑操作}}};return (<divstyle={{ width: '100%', height: '200px', backgroundColor: '#eee' }}onTouchStart={handleTouchStart}onTouchEnd={handleTouchEnd}>在此区域滑动</div>);
};export default SwipeDetector;

注意事项

  1. 阈值选择threshold 值需要根据实际需求调整,太小可能会误触,太大可能导致滑动不灵敏
  2. 性能考虑:避免在touchmove事件中执行复杂操作
  3. 兼容性:现代浏览器都支持触摸事件,但要注意某些旧版本浏览器的兼容性
  4. 被动事件:如果不需要阻止默认行为,可以设置{ passive: true }提高滚动性能
  5. 多指触摸:上述代码只处理单指滑动,如需处理多指手势需要额外逻辑

进阶优化

  1. 可以添加垂直滑动检测,并判断是横向还是纵向滑动
  2. 可以添加滑动过程中的视觉反馈
  3. 可以使用现有的手势库如Hammer.js(https://hammerjs.github.io/)简化开发
<!-- 使用Hammer.js示例 -->
<script src="https://cdn.jsdelivr.net/npm/hammerjs@2.0.8/hammer.min.js"></script>
<script>const element = document.getElementById('swipe-area');const hammer = new Hammer(element);hammer.on('swipeleft', () => console.log('向左滑动'));hammer.on('swiperight', () => console.log('向右滑动'));
</script>
http://www.lryc.cn/news/2387856.html

相关文章:

  • 用户有一个Django模型没有设置主键,现在需要设置主键。
  • 【文献阅读】EndoChat: Grounded Multimodal Large Language Model for Endoscopic Surgery
  • React JSX语法介绍(JS XML)(一种JS语法扩展,允许在JS代码中编写类似HTML的标记语言)Babel编译
  • 【R语言编程绘图-箱线图】
  • 【elasticsearch 7 或8 的安装及配置SSL 操作指引】
  • GitHub 趋势日报 (2025年05月23日)
  • MongoDB索引:原理、实践与优化指南
  • SQL实战之索引优化(单表、双表、三表、索引失效)
  • [7-1] ADC模数转换器 江协科技学习笔记(14个知识点)
  • SSM整合:Spring+SpringMVC+MyBatis完美融合实战指南
  • Spring Boot分页查询进阶:整合Spring Data REST实现高效数据导航
  • 阿里云 Serverless 助力海牙湾构建弹性、高效、智能的 AI 数字化平台
  • 升级node@22后运行npm install报错 distutils not found
  • 一个开源的多播放源自动采集在线影视网站
  • 【PhysUnits】10 减一操作(sub1.rs)
  • 深度检测与动态透明度控制 - 基于Babylon.js的遮挡检测实现解析
  • Linux下使用socat将TCP服务转为虚拟串口设备
  • docker push 报错 denied: requested access to the resource is denied
  • epub→pdf | which 在线转换??好用!!
  • PBX、IP PBX、FXO 、FXS 、VOIP、SIP 的概念解析以及关系
  • MySQL数据高效集成到金蝶云星空的技术分享
  • git 命令之-git cherry-pick
  • 如何在STM32CubeMX下为STM32工程配置调试打印功能
  • Linux系统 - 基本概念
  • kerberos在无痕浏览器 获取用户信息失败 如何判断是否无痕浏览器
  • 在h5端实现录音发送功能(兼容内嵌微信小程序) recorder-core
  • PDF电子发票数据提取至Excel
  • 【身份证识别表格】把大量手机拍摄的身份证信息转换成EXCEL表格的数据,拍的身份证照片转成excel表格保存,基于WPF和腾讯OCR的实现方案
  • FPGA高速接口 mipi lvds cameralink hdml 千兆网 sdi
  • Linux路径解析指南:逻辑路径 vs 实际路径详解