为什么ios浏览器wap 触摸屏幕时 js停止

如题所述

前言诸如智能手机和平板电脑一类的移动设备通常会有一个电容式触摸屏(capacitive touch-sensitive screen),以捕捉用户的手指所做的交互。随着移动网络的发展,其能够支持越来越复杂的应用,web开发者需要一种方法来处理这些事件。例如,几乎所有的快节奏游戏都需要玩家一次按下多个按钮,这种方式,在触摸屏情况下,意味着多点触摸。Apple在iOS 2.0中引入了触摸事件API,Android正迎头赶上这一事实标准,缩小差距。最近一个W3C工作组正合力制定这一触摸事件规范。在本文中,我会深入研究iOS和Android设备提供的触摸事件API,探索一下可以构建哪些类型的应用,给出一些最佳做法,并论及一些使得可触控应用(touch-enabled application)的开发变得更加容易的有用技术。触摸事件三种在规范中列出并获得跨移动设备广泛实现的基本触摸事件:1. touchstart:手指放在一个DOM元素上。2. touchmove:手指拖曳一个DOM元素。3. touchend:手指从一个DOM元素上移开。每个触摸事件都包括了三个触摸列表:1. touches:当前位于屏幕上的所有手指的一个列表。2. targetTouches:位于当前DOM元素上的手指的一个列表。3. changedTouches:涉及当前事件的手指的一个列表。例如,在一个touchend事件中,这就会是移开的手指。这些列表由包含了触摸信息的对象组成:1. identifier:一个数值,唯一标识触摸会话(touch session)中的当前手指。2. target:DOM元素,是动作所针对的目标。3. 客户/页面/屏幕坐标:动作在屏幕上发生的位置。4. 半径坐标和 rotationAngle:画出大约相当于手指形状的椭圆形。可触控应用touchstart、touchmove和touchend事件提供了一组足够丰富的功能来支持几乎是任何类型的基于触摸的交互——其中包括常见的多点触摸手势,比如说捏缩放、旋转等待。下面的这段代码让你使用单指触摸来四处拖曳一个DOM元素:var obj = document.getElementById(‘id’);obj.addEventListener(‘touchmove’, function(event) {// 如果这个元素的位置内只有一个手指的话if (event.targetTouches.length == 1) {var touch = event.targetTouches[0];// 把元素放在手指所在的位置obj.style.left = touch.pageX + ‘px’;obj.style.top = touch.pageY + ‘px’;}}, false);下面是一个示例,该例子显示了屏幕上当前所有的触点,它的作用就是用来感受一下设备的响应性
温馨提示:答案为网友推荐,仅供参考