移动设备上不支持鼠标事件,好在webkit内核的移动浏览器支持 touch 事件,所以触摸事件是移动应用中所必须的。touchstart、touchmove、touchend事件可以类比于mousedown、mouseover、mouseup的触发。

一、touch 相应事件

touchstart : 当手指触摸屏幕时触发;即使已经有一个手指放在了屏幕上也会触发。
touchmove : 当手指在屏幕上滑动时连续的触发。在这个事件发生期间,调用preventDefault()可阻止滚动。
touchend : 当手指从屏幕上移开时触发。
touchcancel : 当系统停止跟踪触摸时触发。关于此事件的确切触发事件,文档中没有明确说明。

以上事件的event对象上面都存在如下属性:
touches : 表示当前跟踪的触摸操作的Touch对象的数组。
targetTouches : 特定于事件目标的Touch对象的数组。
changeTouches : 表示自上次触摸以来发生了什么改变的Touch对象的数组。

每个Touch对象包含下列属性:
clientX : 触摸目标在视口中的X坐标。
clientY : 触摸目标在视口中的Y坐标。
identifier:表示触摸的唯一ID。
pageX:触摸目标在页面中的x坐标。
pageY:触摸目标在页面中的y坐标。
screenX : 触摸目标在屏幕中的x坐标。
screenY : 触摸目标在屏幕中的y坐标。
target : 触摸的DOM节点坐标

二、PC 与 移动端 的适配问题(兼容)  【重点】

既然使用HTML5,当然是看中他的跨平台特性了,不仅仅要iOS和Android适配,pc上直接打开网页最好也是可以的,但是pc上只支持鼠标事件,

所以,解决方案:判断是否pc设备,若是pc,需要更改touch事件为鼠标事件,否则默认触摸事件。

  1. <script>
  2. /*** 手机按下态 * @type {{touchstart: string, touchend: string, initTouchEvents: Function}} */
  3. var touchEvents = {
  4. touchstart: "touchstart",
  5. touchend: "touchend",
  6. initTouchEvents: function () {
    if(!browserRedirect()){
  7. this.touchstart = "mousedown";
  8. this.touchend = "mouseup";
  9. }
  10. }
  11. };
  12. function browserRedirect() {
  13. var sUserAgent = navigator.userAgent.toLowerCase();
  14. var bIsIpad = sUserAgent.match(/ipad/i) == "ipad";
  15. var bIsIphoneOs = sUserAgent.match(/iphone os/i) == "iphone os";
  16. var bIsMidp = sUserAgent.match(/midp/i) == "midp";
  17. var bIsUc7 = sUserAgent.match(/rv:1.2.3.4/i) == "rv:1.2.3.4";
  18. var bIsUc = sUserAgent.match(/ucweb/i) == "ucweb";
  19. var bIsAndroid = sUserAgent.match(/android/i) == "android";
  20. var bIsCE = sUserAgent.match(/windows ce/i) == "windows ce";
  21. var bIsWM = sUserAgent.match(/windows mobile/i) == "windows mobile";
  22. if (bIsIpad || bIsIphoneOs || bIsMidp || bIsUc7 || bIsUc || bIsAndroid || bIsCE || bIsWM) {
  23. return true; // 移动设备
  24. } else {
  25. return false; // PC
  26. }
  27. }
  28.  
  29. var phone = document.getElementById("phone");
  30. touchEvents.initTouchEvents();
  31. phone.addEventListener(touchEvents.touchstart, function (e) {
  32. var self=this;
  33. self.style.background = "red";
  34. e.stopPropagation();
  35. e.preventDefault();
  36.  
  37. });
  38.  
  39. phone.addEventListener(touchEvents.touchend, function (e) {
  40. var self=this;
  41. self.style.background = "blue";
  42. e.stopPropagation();
  43. e.preventDefault();
  44. });
  45.  
  46. </script>

页面上:

  1. <style>
  2. * { margin:; padding:; }
  3. a { display: block;width: 200px;font-size: 16px; text-align: center; line-height: 80px;cursor: pointer;margin: 50px;}
  4. .phone { background: green; }
  5. </style>
  1. <a id="phone" class="phone">请点击我</a>

就是这样,若在pc上,则使用鼠标事件;在移动设备中,就使用触摸事件。

 效果展示:

1、PC端:

(1)初始:

(2)鼠标在 a 上按下:

(3)鼠标在 a 上松开:

2、手机端:

(1)初始:

(2)手指在 a 上按下:

额,这个截不到图。。。但是亲测手指按在 a 上即触发 touchstart 事件, a 背景色变为红色。

(3)手指从 a 上拿开:

移动端—— 兼容PC端,移动端的点击事件的更多相关文章

  1. 一个 VUE 组件:实现子元素 scroll 父元素容器不跟随滚动(兼容PC、移动端)

    介绍 我们经常遇到一种情况.当滑动滚动条区域时,子元素滚动条到底部或顶部时就会触发父级滚动条,父级滚动条同理会继续向上触发,直至body容器.这是浏览器默认的滚动行为. 但是很多情况,我们想要子元素滚 ...

  2. 手把手教你做一个原生js拖动滑块【兼容PC和移动端】

    废话少说: 在PC端可以用mousedown来触发一个滑块滑动的效果,但在手机上,貌似无法识别这个事件,但手机上有touchstart事件,可以通过一系列"touch"事件来替代P ...

  3. 堆叠相冊效果,兼容pc和移动端

    在手机端,堆叠效果的相冊是比較常见的一种图片展示方式,每一个人的思路可能会有一些不同,实现的方法不同. 本篇博客主要是分享下我的实现方法.欢迎大家提出建议,指出我的不足,先3Q啦~ 先看一下终于的效果 ...

  4. scrollMenu,一款可滚动的菜单插件 兼容pc和移动端

    这个菜单 有两种样式  , 也可以通过animate.css加不同的动画效果!滚动的方式也有两种   一种为通用的overflow,另外一种是better-scroll的滚动效果 在线链接地址  ht ...

  5. 一款多功能的移动端滚动选择器,支持单选到多选、支持多级级联、提供自定义回调函数、提供update函数二次渲染、重定位函数、兼容pc端拖拽等等..

    https://github.com/onlyhom/mobileSelect.js/blob/master/docs/README-CN.md mobileSelect.js 一款多功能的移动端滚动 ...

  6. 网页背景H5视频自动播放---PC端、移动端兼容问题完美解决方案(IOS、安卓、微信端)

    最近公司官网需要使用视频当做banner背景且自动播放,并且因为是官网需要做到PC端和移动端都可以适配兼容,这些问题很是头疼: 兵来将挡,水来土掩,进过查阅相关技术资料,现已完美兼容PC端和移动端.下 ...

  7. 【移动端兼容问题研究】javascript事件机制详解(涉及移动兼容)

    前言 这篇博客有点长,如果你是高手请您读一读,能对其中的一些误点提出来,以免我误人子弟,并且帮助我提高 如果你是javascript菜鸟,建议您好好读一读,真的理解下来会有不一样的收获 在下才疏学浅, ...

  8. 前端判断用户请求是PC还是移动端

    链接:https://www.zhihu.com/question/20004700/answer/13678113 第一步先在服务器端使用User Agent判断,先匹配出移动设备,这一步可以统计U ...

  9. JS判断PC还是移动端打开网页

    最近在做移动端网站,也需兼容PC端.还没找到更好的方法,只能用javascr判断用户是在PC端打开还是移动端打开. JS判断 var isPC = function (){    var userAg ...

随机推荐

  1. Android Parcelable 序列化复杂数据结构

    参考博文 http://blog.csdn.net/yangzl2008/article/details/7593226 由于项目需要,Activity之间要传递一个特别复杂的数据结构对象,由于以前序 ...

  2. OpenCV手工实现灰度及RGB直方图

    手工实现灰度及RGB直方图 !库 1. 灰度图像直方图 算法 1. 图片灰度化: 2. 遍历Mat,统计各灰度级的像素个数: 3. 根据opencv画点线函数,绘制坐标轴及像素分布图 源码(编译环境: ...

  3. jquery操作select下拉框:取值,赋值,删除

    1.jQuery对select的取值 <select id="test"> <option value ="1">测试1</opt ...

  4. EditText编辑框

    <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...

  5. 【Day5】2.反爬策略之代理IP

    import urllib.request as ur proxy_address = ur.urlopen('http://api.ip.data5u.com/dynamic/get.html?or ...

  6. 【2017-07-03】JS连续删除table中的选中的多行数据

    deleteRow() 连续删除多行 应用:删除表格选中的一行或多行.html代码如下: <table > <tr> <td >复选框</td> < ...

  7. linux /etc/shadow文件详解

    struct spwd { char *sp_namp; /* user login name */ char *sp_pwdp; /* encrypted password */ long int ...

  8. 创建守护进程步骤与setsid()

    原创:http://www.cnblogs.com/mickole/p/3188321.html 一,守护进程概述 Linux Daemon(守护进程)是运行在后台的一种特殊进程.它独立于控制终端并且 ...

  9. Pytest编写测试函数

    Pytest编写测试函数 一个规范的测试方法一定带有断言,在使用pytest时,可以直接使用Python自带的assert关键字 Pytest允许在assert关键字添加任意表达式,表达式的值通过bo ...

  10. http协议头

    1. ctx->AddResponseHeader("Content-Type", "application/octet-stream"); ctx-&g ...