移动端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
相关推荐
m0_5180194811 分钟前
C++与机器学习框架
开发语言·c++·算法
wefly201713 分钟前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
ZTLJQ14 分钟前
深入理解逻辑回归:从数学原理到实战应用
开发语言·python·机器学习
qq_4176950517 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
C澒1 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro1 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
波波0071 小时前
每日一题:.NET 中的“反射”是什么?
开发语言·.net
木斯佳1 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授1 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
qq_461489331 小时前
C++与Qt图形开发
开发语言·c++·算法