移动端h5 js手势封装

原文 https://blog.csdn.net/qq_43248623/article/details/115300072
这里对原代码做了一点小小的优化,做了个封装

// 手势封装
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

相关推荐

  1. 移动h5 js手势封装

    2024-04-07 19:30:02       42 阅读
  2. 解决h5移动touchend事件不灵敏的问题-hammer.js

    2024-04-07 19:30:02       34 阅读
  3. H5/微信 Video标签移动播放问题

    2024-04-07 19:30:02       69 阅读
  4. Material-UI create-react-app 创建移动 H5

    2024-04-07 19:30:02       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-07 19:30:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-07 19:30:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-07 19:30:02       87 阅读
  4. Python语言-面向对象

    2024-04-07 19:30:02       96 阅读

热门阅读

  1. C# 索引器的范例和要点

    2024-04-07 19:30:02       47 阅读
  2. leetcode热题100.数组中的第k大的元素

    2024-04-07 19:30:02       38 阅读
  3. [leetcode] 66. 加一

    2024-04-07 19:30:02       35 阅读
  4. GPU的了解

    2024-04-07 19:30:02       47 阅读
  5. Redis实现网站访问人数统计

    2024-04-07 19:30:02       43 阅读
  6. 设计模式:观察者模式

    2024-04-07 19:30:02       44 阅读
  7. 全量知识系统 设计和实现的切入点探讨 (Q&A)

    2024-04-07 19:30:02       36 阅读
  8. 数据库面试题之Mysql

    2024-04-07 19:30:02       38 阅读