移动端h5 js手势封装

原文 https://blog.csdn.net/qq_43248623/article/details/115300072

这里对原代码做了一点小小的优化,做了个封装

js 复制代码
// 手势封装
const handlerSwiper = (domClass, cb) => {
    const dom = document.querySelector(domClass)
    var startx, starty;
    //获得角度
    function getAngle(angx, angy) {
        return Math.atan2(angy, angx) * 180 / Math.PI;
    };

    //根据起点终点返回方向 1向上滑动 2向下滑动 3向左滑动 4向右滑动 0点击事件
    function getDirection(startx, starty, endx, endy) {
        var angx = endx - startx;
        var angy = endy - starty;
        var result = 0;

        //如果滑动距离太短
        if (Math.abs(angx) < 2 && Math.abs(angy) < 2) {
            return result;
        }

        var angle = getAngle(angx, angy);
        if (angle >= -135 && angle <= -45) {
            result = 1;
        } else if (angle > 45 && angle < 135) {
            result = 2;
        } else if ((angle >= 135 && angle <= 180) || (angle >= -180 && angle < -135)) {
            result = 3;
        } else if (angle >= -45 && angle <= 45) {
            result = 4;
        }
        return result;
    }

    //手指接触屏幕
    //  let box = document.querySelector('#box')
    dom.addEventListener("touchstart", function (e) {
        startx = e.touches[0].pageX;
        starty = e.touches[0].pageY;
    }, false);

    //手指离开屏幕
    dom.addEventListener("touchend", function (e) {
        var endx, endy;
        endx = e.changedTouches[0].pageX;
        endy = e.changedTouches[0].pageY;
        var direction = getDirection(startx, starty, endx, endy);
        // 0点击  1向上 2向下 3向左 4向右
        // 各个方向操作逻辑写在回调函数内
        cb(direction)
    }, false);
}

// 使用方式:
// 0点击  1向上 2向下 3向左 4向右

// function doExample(n) {
//     // console.log(n);
//     if (n === 0) {
//         console.log('点击');
//     }
//     if (n === 1) {
//         console.log('向上');
//     }
//     if (n === 2) {
//         console.log('向下');
//     }
//     if (n === 3) {
//         console.log('向左');
//     }
//     if (n === 4) {
//         console.log('向右');
//     }
// }
// handlerSwiper('#box', doExample)

export default handlerSwiper
相关推荐
火柴盒zhang几秒前
websheet在线电子表格(spreadsheet)在集团型企业财务报表中的应用
前端·html·报表·合并·spreadsheet·websheet·集团财务
讨厌吃蛋黄酥几秒前
智能前端新纪元:语音交互技术与安全实践全解析
javascript
khalil2 分钟前
基于 Vue3实现一款简历生成工具
前端·vue.js
向阳@向远方9 分钟前
第二章 简单程序设计
开发语言·c++·算法
拾光拾趣录9 分钟前
浏览器对队头阻塞问题的深度优化策略
前端·浏览器
用户8122199367229 分钟前
[已完结]后端开发必备高阶技能--自研企业级网关组件(Netty+Nacos+Disruptor)
前端
万少14 分钟前
2025中了 聊一聊程序员为什么都要做自己的产品
前端·harmonyos
1234Wu29 分钟前
React Native 接入 eCharts
javascript·react native·react.js
Mr_Xuhhh40 分钟前
信号与槽的总结
java·开发语言·数据库·c++·qt·系统架构
纳兰青华1 小时前
bean注入的过程中,Property of ‘java.util.ArrayList‘ type cannot be injected by ‘List‘
java·开发语言·spring·list