LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

Hammer.js,一款用于手机屏幕移动端开发的神奇 JavaScript 开源多点触摸手势库

admin
2024年10月12日 10:7 本文热度 430
  • • Github Star: 24k[1]

  • • 官网[2]

1、Hammer.js 是什么?

Hammer.js 是一个开源的轻量级 JavaScript 库,专门用于识别和处理移动设备上的触摸手势。它能够识别包括点击、双击、拖动、缩放、旋转等多种手势,可以在不依赖其他框架的情况下独立使用,而且很轻量压缩后仅 7.34KB。Hammer.js 的设计目的是简化移动端开发中的手势识别过程,提供高性能的交互体验.

核心特性

  • • 手势识别:提供了一系列预设的手势识别器,如拖动、缩放、旋转等,并且允许自定义新的手势识别器。

  • • 事件处理:通过简单的 API,开发者可以为特定的手势绑定事件处理函数,实现自定义的交互逻辑。

  • • 性能优化:进行了性能优化,减少不必要的计算并有效利用硬件加速,保证流畅的用户体验。

  • • 跨平台支持:兼容多种移动设备和桌面浏览器,确保广泛的应用范围.

2、应用场景

Hammer.js 应用于需要精细触摸交互的移动 Web 应用和游戏开发中。它可以用于实现图片轮播、地图缩放、游戏控制等功能。

3、快速开始

在项目中使用 Hammer.js ,需要通过 npm 或 yarn 将 Hammer.js 安装。

npm install --save hammerjs
# 或
yarn add hammerjs

示例代码中,使用 CDN 引入 Hammer.js。首先定义 DOM 结构如下:

<div id="app">
  <div class="wrapper">
    <div class="square" id="tap">轻击</div>
    <div class="square" id="doubleTap">双击</div>
    <div class="square" id="press">长按</div>
    <div class="square" id="swipe">滑动</div>
  </div>
</div>
<script
  src="https://cdnjs.cloudflare.com/ajax/libs/hammer.js/2.0.8/hammer.js"
  integrity="sha512-qRj8N7fxOHxPkKjnQ9EJgLJ8Ng1OK7seBn1uk8wkqaXpa7OA13LO6txQ7+ajZonyc9Ts4K/ugXljevkFTUGBcw=="
  crossorigin="anonymous"
  referrerpolicy="no-referrer"
>
</script>
<script type="module" src="./index.js"></script>

创建 Hammer 对象,定义识别器和注册回调事件。

const $ = e => document.querySelector(e)
// 轻击事件
const tapManager = new Hammer.Manager($('#tap'))
// 定义触发器
const tap = new Hammer.Tap({
  taps1
})
// 添加到 manager 中
tapManager.add(tap)
// 注册回调
tapManager.on('tap'(e) => {
  e.target.classList.toggle('expand');
});

效果如下(具体实现回复 “demo”获取)

4、核心API

手势识别事件

Hammer.js 支持多种手势识别,以下是一些常用的识别器:

  • • Pan 事件:手指按下并移动,就是触摸屏的拖动。包括 panstartpanmovepanendpancancel以及方向性事件如panleftpanrightpanuppandown

  • • Pinch 事件:当两根手指或多根手指相对移动或相向移动时触发。包括 pinchstartpinchmovepinchendpinchcancel 以及 pinchn(手指距离变近)和 pinchout(手指距离变远)事件

  • • Rotate 事件:当两根手指或更多手指呈圆形旋转时触发。包括 rotatestartrotatemoverotateend 和 rotatecancel 事件 。

  • • Press 事件:在指定的DOM对象中,进行按压的点击事件,相当于 PC 端的 click 事件,最小按压时间为500ms。包括 pressup 事件 。

  • • Tap 和 Doubletap 事件:点按和双击手势。

  • • Swipe 事件:快速滑动手势,可以设置方向性,例如仅水平或垂直方向

Hammer.js 允许同时监听多个手势、自定义识别器,并且可以通过 recognizeWith和 requireFailure 等方法来定义识别器之间的关系 。默认情况下,pinch 和 rotate 识别器是禁用的,如果需要使用它们,可以通过设置 enable: true 来启用 。

5、总结

Hammer.js,这个小巧的 JavaScript 库让移动设备上的手势操作变得超简单。不管是轻点、滑动还是捏合放大,它都能轻松识别,而且用起来特别方便。小伙伴们可以快速上手,给自己的项目加上各种酷炫的手势功能。

祝好!

引用链接

[1] Github Star: 24k: https://github.com/hammerjs/hammer.js
[2] 官网: https://hammerjs.github.io


该文章在 2024/10/12 10:07:43 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved