hammer.js是一个多点触摸手势库,能够为网页加入Tap、Double Tap、Swipe、Hold、Pinch、Drag等多点触摸事件,免去自己监听底层touchstart、touchmove、touchend事件并且写一大堆判断逻辑的痛苦。hammer.js不但支持触摸屏设备的浏览器,在桌面浏览器上,也能将鼠标的点击当做触摸,方便开发人员在桌面浏览器上调试。这是一个专为触摸手势而生的js库,对有需要的朋友非常有帮助,奉上常用的一些方法调用文档。

使用方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 
// 先要对监听的DOM进行一些初始化
var hammer = new Hammer(document.getElementById("container"));
 
// 然后加入相应的回调函数即可
hammer.ondragstart = function(ev) { };  // 开始拖动
hammer.ondrag = function(ev) { }; // 拖动中
hammer.ondragend = function(ev) { }; // 拖动结束
hammer.onswipe = function(ev) { }; // 滑动
 
hammer.ontap = function(ev) { }; // 单击
hammer.ondoubletap = function(ev) { }; //双击
hammer.onhold = function(ev) { }; // 长按
 
hammer.ontransformstart = function(ev) { }; // 双指收张开始
hammer.ontransform = function(ev) { }; // 双指收张中
hammer.ontransformend = function(ev) { }; // 双指收张结束
 
hammer.onrelease = function(ev) { }; // 手指离开屏幕

还支持jQuery插件的形式调用

1
2
3
4
5
6
7
8
9
 
$("#element")
   .hammer({
        // 对DOM进行一些初始化,这里可以加入一些参数。不是必须的
   })
   .bind("tap", function(ev) {
        console.log(ev);
   });

官网地址:http://eightmedia.github.com/hammer.js/  (带演示)
源码地址:https://github.com/EightMedia/hammer.js

一、前言

移动端框架当前还处在初级阶段,但相对于移动端的应用来说已经有很长时间了。虽然暂时还没有PC端开发的需求量大,但移动端的Web必然是一种趋 势,在接触移动端脚本的过程中,最开始想到的是juqery。Jquery2.0版本及以上已经开始偏向移动端,如对h5的支持,但支持还是不够完善,希 望jq在后面的版本能够逐渐支持起来。

最初在开发移动端Web的时候使用w3c标准的语法结构和原生的js开发,但相对来说开发量比较大,而且每一步都要考虑各移动端浏览器的兼容,像比 较让程序员头痛的大wp手机,很多事件都向w3c申请单独的标准。因此一个好的兼容性架构对于开发者来说可以节省很大一部分工作量。

刚开始接触移动端框架之初也问了一些一直搞前端的朋友,大部份都在百度阿里等工作。参考大家的建议后我们做项目使用了zepto.js(很多搞前端 的朋友应该并不陌生)。这个框架有个很大的问题就是不兼容wp手机,使用zepto.js开发完项目后,再针对wp手机兼容做调整总感觉有些“得不偿 失”,后来咨询了些朋友,他们所在的公司在开发的时候基本都放弃wp的兼容(我只能对wp说“呵呵”了)。后面就咨询到有用hammer.js进行开发 的。我们研究了下,hammer.js轻量级,封装的也比较好。用起来也很方便。兼容性也不错。但网上中文资料比较少,园子写hammer的就更少了。因 此有了这篇文章。

此文章基于hammer.js 官网:http://hammerjs.github.io/ ,版本基于v2.0.4。如果该文章的api已过期,请自行到官网查询最新api。此文章只做入门使用。

二、hammer.js是什么

hammer.js是一款开源的移动端脚本框架,他可以完美的实现在移端开发的大多数事件,如:点击、滑动、拖动、多点触控等事件。不需要依赖任何其他的框架,并且整个框架非常小,\在使用时非常简单,代码示例如下:

  1. 1 <div id="test" class="test"></div>
  2. 2 <script type="text/javascript">
  3. 3 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  4. 4 var hammertime = new Hammer(document.getElementById("test"));
  5. 5 //为该dom元素指定触屏移动事件
  6. 6 hammertime.on("pan", function (ev) {
  7. 7 //控制台输出
  8. 8 console.log(ev);
  9. 9 });
  10. 10 </script>

三事件架构

hammer.js主要针对触屏的6大事件进行监听。如下图所示:

1、  Pan事件:在指定的dom区域内,一个手指放下并移动事件,即触屏中的拖动事件。这个事件在屏触开发中比较常用,如:左拖动、右拖动等,如手要上使用QQ时向右滑动出现功能菜单的效果。该事件还可以分别对以下事件进行监听并处理:

Panstart:拖动开始、Panmove:拖动过程、Panend:拖动结束、Pancancel:拖动取消、Panleft:向左拖动、Panright:向右拖动、Panup:向上拖动、Pandown:向下拖动

2、  Pinch事件:在指定的dom区域内,两个手指(默认为两个手指,多指触控需要单独设置)或多个手指相对(越来越近)移动或相向(越来越远)移动时事件。该事件事以分别对以下事件进行监听并处理:

Pinchstart:多点触控开始、Pinchmove:多点触控过程、Pinchend:多点触控结束、Pinchcancel:多点触控取消、Pinchin:多点触控时两手指距离越来越近、Pinchout:多点触控时两手指距离越来越远

3、  Press事件:在指定的dom区域内触屏版本的点击事件,这个事件相当于PC端的Click事件,该不能包含任何的移动,最小按压时间为500毫秒,常用于我们在手机上用的“复制、粘贴”等功能。该事件分别对以下事件进行监听并处理:

Pressup:点击事件离开时触发

4、  Rotate事件:在指定的dom区域内,当两个手指或更多手指成圆型旋转时触发(就像两个手指拧螺丝一样)。该事件分别对以下事件进行监听并处理:

Rotatestart:旋转开始、Rotatemove:旋转过程、Rotateend:旋转结束、Rotatecancel:旋转取消

5、  Swipe事件:在指定的dom区域内,一个手指快速的在触屏上滑动。即我们平时用到最多的滑动事件。

Swipeleft:向左滑动、Swiperight:向右滑动、Swipeup:向上滑动、Swipedown:向下滑动

6、Tap事件:在指定的dom区域内,一个手指轻拍或点击时触发该事件(类似PC端的click)。该事件最大点击时间为250毫秒,如果超过250毫秒则按Press事件进行处理。

经验分享:写到这个事件的时候有人必然要问了,在触屏中我们使用Click事件不也可以吗?这个Tap事件与Click事件有什么区别呢?博主也曾 经有过这样的疑惑,起初在触屏上处理点击的时候也一直用的click事件,并且没也有出现任何问题,直到有一天为一个公司做了微信版本的“连连看”小游 戏,连连看的业务简单来说就是屏幕上有很多图片,当点击两个相同图案的图片时可以在中间产生连接线,并且产生爆破效果后消失。这个游戏刚开始做的时候是在 ff浏览器上做的测试,鼠标点击后效果非常流畅,但当游戏部署到服务器上并用手机端操作时,iphone和wp都非常流畅,安卓下不管怎么调都是有卡顿。 起初以为是手机性能的问题,但换了高配手机后仍然会有卡顿,游戏也不是不能玩,就是反应慢。经过多次的测试后排除了手机配置的硬件原因,开始怀疑 click事件。经过网上查阅后才得知,在安卓触屏上,Tap事件和click事件可以同时触发,但click事件会有几百毫秒的延迟,即先触发Tap事 件,过一段时间再触发click事件。后来把游戏的所有click事件修改成Tap事件问题就自然解决了。

四、 使用实例

1、 Pan

代码如下:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <meta name="viewport" content="width=device-width" />
  5. 5 <title>Pan</title>
  6. 6 <script src="/Script/hammer.js"></script>
  7. 7 <style type="text/css">
  8. 8 html, body {
  9. 9 width: 100%;
  10. 10 height: 100%;
  11. 11 margin: 0px;
  12. 12 padding: 0px;
  13. 13 }
  14. 14
  15. 15 .test {
  16. 16 width: 100%;
  17. 17 height: 50%;
  18. 18 background: #ffd800;
  19. 19 text-align: left;
  20. 20 }
  21. 21
  22. 22 .result {
  23. 23 width: 100%;
  24. 24 height: 50%;
  25. 25 background: #b6ff00;
  26. 26 text-align: left;
  27. 27 }
  28. 28 </style>
  29. 29 </head>
  30. 30 <body>
  31. 31 <div id="test" class="test">事件区域</div>
  32. 32 <div id="result" class="result">事件结果<br /></div>
  33. 33 <script type="text/javascript">
  34. 34 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  35. 35 var hammertime = new Hammer(document.getElementById("test"));
  36. 36 //添加事件
  37. 37 hammertime.on("pan", function (e) {
  38. 38 document.getElementById("result").innerHTML += "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
  39. 39 //控制台输出
  40. 40 console.log(e);
  41. 41 });
  42. 42 </script>
  43. 43 </body>
  44. 44 </html>

效果如下:

2、Pinch

代码如下:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <meta name="viewport" content="width=device-width" />
  5. 5 <title>Pinch</title>
  6. 6 <script src="/Script/hammer.js"></script>
  7. 7 <style type="text/css">
  8. 8 html, body {
  9. 9 width: 100%;
  10. 10 height: 100%;
  11. 11 margin: 0px;
  12. 12 padding: 0px;
  13. 13 }
  14. 14
  15. 15 .test {
  16. 16 width: 100%;
  17. 17 height: 50%;
  18. 18 background: #ffd800;
  19. 19 text-align: left;
  20. 20 }
  21. 21
  22. 22 .result {
  23. 23 width: 100%;
  24. 24 height: 50%;
  25. 25 background: #b6ff00;
  26. 26 text-align: left;
  27. 27 }
  28. 28 </style>
  29. 29 </head>
  30. 30 <body>
  31. 31 <div id="test" class="test">事件区域</div>
  32. 32 <div id="result" class="result">事件结果:捏合触发<br /></div>
  33. 33 <script type="text/javascript">
  34. 34 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  35. 35 var hammertime = new Hammer(document.getElementById("test"));
  36. 36 //为该dom元素指定触屏移动事件
  37. 37 hammertime.add(new Hammer.Pinch());
  38. 38 //添加事件
  39. 39 hammertime.on("pinchin", function (e) {
  40. 40 document.getElementById("result").innerHTML += "捏合初触发<br />";
  41. 41 //控制台输出
  42. 42 console.log(e);
  43. 43 });
  44. 44 </script>
  45. 45 </body>
  46. 46 </html>

效果如下:

3、Press

代码如下:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <meta name="viewport" content="width=device-width" />
  5. 5 <title>Press</title>
  6. 6 <script src="/Script/hammer.js"></script>
  7. 7 <style type="text/css">
  8. 8 html, body {
  9. 9 width: 100%;
  10. 10 height: 100%;
  11. 11 margin: 0px;
  12. 12 padding: 0px;
  13. 13 }
  14. 14
  15. 15 .test {
  16. 16 width: 100%;
  17. 17 height: 50%;
  18. 18 background: #ffd800;
  19. 19 text-align: left;
  20. 20 }
  21. 21
  22. 22 .result {
  23. 23 width: 100%;
  24. 24 height: 50%;
  25. 25 background: #b6ff00;
  26. 26 text-align: left;
  27. 27 }
  28. 28 </style>
  29. 29 </head>
  30. 30 <body>
  31. 31 <div id="test" class="test">事件区域</div>
  32. 32 <div id="result" class="result">事件结果:按压超过500ms触发<br /></div>
  33. 33 <script type="text/javascript">
  34. 34 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  35. 35 var hammertime = new Hammer(document.getElementById("test"));
  36. 36 //添加事件
  37. 37 hammertime.on("press", function (e) {
  38. 38 document.getElementById("result").innerHTML += "超过500ms了<br />";
  39. 39 //控制台输出
  40. 40 console.log(e);
  41. 41 });
  42. 42 </script>
  43. 43 </body>
  44. 44 </html>

效果如下:

4、Rotate

代码如下:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <meta name="viewport" content="width=device-width" />
  5. 5 <title>Rotate</title>
  6. 6 <script src="/Script/hammer.js"></script>
  7. 7 <style type="text/css">
  8. 8 html, body {
  9. 9 width: 100%;
  10. 10 height: 100%;
  11. 11 margin: 0px;
  12. 12 padding: 0px;
  13. 13 }
  14. 14
  15. 15 .test {
  16. 16 width: 100%;
  17. 17 height: 50%;
  18. 18 background: #ffd800;
  19. 19 text-align: left;
  20. 20 }
  21. 21
  22. 22 .result {
  23. 23 width: 100%;
  24. 24 height: 50%;
  25. 25 background: #b6ff00;
  26. 26 text-align: left;
  27. 27 }
  28. 28 </style>
  29. 29 </head>
  30. 30 <body>
  31. 31 <div id="test" class="test">事件区域</div>
  32. 32 <div id="result" class="result">事件结果:旋转触发<br /></div>
  33. 33 <script type="text/javascript">
  34. 34 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  35. 35 var hammertime = new Hammer(document.getElementById("test"));
  36. 36 //为该dom元素指定触屏移动事件
  37. 37 hammertime.add(new Hammer.Rotate());
  38. 38 //添加事件
  39. 39 hammertime.on("rotate", function (e) {
  40. 40 document.getElementById("result").innerHTML += "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
  41. 41 //控制台输出
  42. 42 console.log(e);
  43. 43 });
  44. 44 </script>
  45. 45 </body>
  46. 46 </html>

效果如下:

5、Swipe

代码如下:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <meta name="viewport" content="width=device-width" />
  5. 5 <title>Swipe</title>
  6. 6 <script src="/Script/hammer.js"></script>
  7. 7 <style type="text/css">
  8. 8 html, body {
  9. 9 width: 100%;
  10. 10 height: 100%;
  11. 11 margin: 0px;
  12. 12 padding: 0px;
  13. 13 }
  14. 14
  15. 15 .test {
  16. 16 width: 100%;
  17. 17 height: 50%;
  18. 18 background: #ffd800;
  19. 19 text-align: left;
  20. 20 }
  21. 21
  22. 22 .result {
  23. 23 width: 100%;
  24. 24 height: 50%;
  25. 25 background: #b6ff00;
  26. 26 text-align: left;
  27. 27 }
  28. 28 </style>
  29. 29 </head>
  30. 30 <body>
  31. 31 <div id="test" class="test">事件区域</div>
  32. 32 <div id="result" class="result">事件结果:向左滑动触发<br /></div>
  33. 33 <script type="text/javascript">
  34. 34 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  35. 35 var hammertime = new Hammer(document.getElementById("test"));
  36. 36 //添加事件
  37. 37 hammertime.on("swipeleft", function (e) {
  38. 38 document.getElementById("result").innerHTML += "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
  39. 39 //控制台输出
  40. 40 console.log(e);
  41. 41 });
  42. 42 </script>
  43. 43 </body>
  44. 44 </html>

效果如下:

6、Tab

代码如下:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <meta name="viewport" content="width=device-width" />
  5. 5 <title>Tap</title>
  6. 6 <script src="/Script/hammer.js"></script>
  7. 7 <style type="text/css">
  8. 8 html, body {
  9. 9 width: 100%;
  10. 10 height: 100%;
  11. 11 margin: 0px;
  12. 12 padding: 0px;
  13. 13 }
  14. 14
  15. 15 .test {
  16. 16 width: 100%;
  17. 17 height: 50%;
  18. 18 background: #ffd800;
  19. 19 text-align: left;
  20. 20 }
  21. 21
  22. 22 .result {
  23. 23 width: 100%;
  24. 24 height: 50%;
  25. 25 background: #b6ff00;
  26. 26 text-align: left;
  27. 27 }
  28. 28 </style>
  29. 29 </head>
  30. 30 <body>
  31. 31 <div id="test" class="test">事件区域</div>
  32. 32 <div id="result" class="result">事件结果:点击触发<br /></div>
  33. 33 <script type="text/javascript">
  34. 34 //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
  35. 35 var hammertime = new Hammer(document.getElementById("test"));
  36. 36 //添加事件
  37. 37 hammertime.on("tap", function (e) {
  38. 38 document.getElementById("result").innerHTML += "点击触发了,长按无效<br />";
  39. 39 //控制台输出
  40. 40 console.log(e);
  41. 41 });
  42. 42 </script>
  43. 43 </body>
  44. 44 </html>

效果如下:

上述的实例还是有所区别的。在Pinch事件和Rotate事件中,我们用了hammertime.add(new Hammer.Pinch());和hammertime.add(new Hammer.Rotate ());而其他四个事件没有用,而是直接添加了事件的监听程序。原因在于,我们在new Hammer(htmlElement)的时候,Hammer.js默认对Pan、Press、Swipe和Tab事件进行了监听。但没有对Pinch和 Rotate事件进行监听。

Hammer.js移动端触屏框架的使用的更多相关文章

  1. js移动端触屏事件

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  2. JS案例之5——移动端触屏滑动

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  3. 移动端触屏滑动,JS事件

    先了解下 移动端的触屏滑动 毕竟这玩意其实和PC端还是有一定的区别的 hh 整理了下网上的资料放一放 移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等 ...

  4. 【转载】jQuery手机移动端触屏日历日期选择

    文章转载自 科e互联 http://www.internetke.com/ 原文链接:http://www.internetke.com/effects/css3/2015/0120/1222.htm ...

  5. zepto.js swipe实现触屏tab菜单

    今天我们来说下zepto.js,有兴趣的朋友可以先进这个网站“http://zeptojs.com/” ,这个可以说是手机里的jquery,但是它取消了hover,加上了swipe及tap这两个触屏功 ...

  6. 移动端触屏click点击事件延迟问题,以及tap的解决方案

    在移动端 触屏click事件虽然也会响应,但是总感觉是有延迟,一直听说click事件在手机上有200~300毫秒的延迟问题,亲自测了一下,在pc端模拟手机的话是测不出来的,但是用手机测试时发现延迟非常 ...

  7. 自己用原生JS写的轮播图,支持移动端触屏滑动,面向对象思路。分页器圆点支持click和mouseover。

    自己用原生javascript写的轮播图,面向对象思路,支持移动端手指触屏滑动.分页器圆点可以选择click点击或mouseover鼠标移入时触发.图片滚动用的setInterval,感觉setInt ...

  8. Hammer.js 移动端手势库,多点触控插件

    jquery用法: 引入3个JS:<script src="jquery.js"></script> <script src="hammer ...

  9. zTouch-移动端触屏开发利器(zepto touch扩展)

    * Zepto.js v1.0.1 touch extend (Zepto.js v1.0.1 的swipe touch扩展)js-处理手机移动端web触屏手势动作. Zepto.js v1.0.1版 ...

随机推荐

  1. 【kate总结】Matlab坐标轴问题

    [kate总结]Matlab坐标轴问题 总结而言 行óYó高ó垂直 列óXó宽ó水平 Maplab中存有2张图片 1.JPG 宽(列):320    高(行):482 在matlab中显示 2.JPG ...

  2. 关于SharePoint REST中的授权的研究

    博客地址:http://blog.csdn.net/FoxDave 当我们开发SharePoint APP需要调用REST服务时,可以使用OAuth完成授权,也可以使用跨域库.以下是微软专家的一段注解 ...

  3. UIControl的使用

    在开发当中,可能很多时候都需要做个点赞的需求,如果用按钮实现,按钮作为一个系统复合控件,外部是一个 View-->UIControl的容器, 内部包含了UILabel和UIImage,以及一些排 ...

  4. HDU2073(暴力) VS HDU5214(贪心)

    题意:给出n组l[i],r[i],求出能够相互连接的最大个数,比如(1,2) ,(2,3),(5,6)就是可以连接的3组数据: 思路:2073数组大小为100,纯暴力就可以了,不过注意排序时,按照r的 ...

  5. xp默认安装路径及本地用户配置文件存放路径修改

    xp默认安装路径及本地用户配置文件存放路径修改 修改注册表可能会造成您的系统崩溃或数据丢失,请先行备份操作系统,以备不测!!! 备份注册表步骤: 1.在“桌面”上按快捷键“Ctrl+R”,调出“运行” ...

  6. Egret

    http://www.manew.com/forum-html5Engine-1.html http://www.manew.com/forum-html5Engine-1.html https:// ...

  7. Unity3D ShaderLab 车辆喷漆光照模型实战

    这一篇,我们来创建一个车辆喷漆的光照模型.首先就是准备场景,新建Shader & Material. 过程比较简单,直接看完成的代码吧: Shader "91YGame/CarOut ...

  8. 制作0.5px像素的细条

    <!DOCTYPE html><html><head> <meta charset="utf-8"> <meta name=& ...

  9. hdu 3172

    http://acm.hdu.edu.cn/showproblem.php?pid=3172 题意:输出每对朋友的关系网大小 并查集的时候维护一个数组记录根节点的大小即可,水题,这题坑在T组数据这个也 ...

  10. Smart210---学习记录 竞态与并发

    竞态与并发 自旋锁 若一个进程要访问临界资源,测试锁空闲,则进程获得这个锁并继续执行:若测试结果表明锁扔被 占用,进程将在一个小的循环内重复“测试并设置”操作,进行所谓的“自旋”,等待自旋锁持有者释 ...