首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

移动端的touch事件处理

在这个事件发生期间,调用preventDefault()事件可以阻止滚动。  touchend事件:当手指从屏幕上离开的时候触发。  touchcancel事件:当系统停止跟踪触摸的时候触发。...这个时候,有一个有趣的问题就是,如果你以一个触点(一根手指)来操作的话,touches和targetTouches两个属性,当这个触点(这根手指)离开屏幕,触发touchend事件时,这两个属性中,是不包含任何对象的...从上面的两点,也可以理解到,这三个属性之间的差距,就拿touchend事件时的情况来说明吧(这个比较好理解),当touchend被触发时,手指时离开屏幕了,所以此时的touches和targetTouches...属性的属性值,是不会再包含这个刚离开的触点的信息的,所以,当一个触点触发touchend事件时,touches和targetTouches属性值中的touch对象个数就是0了,表示当前一个触点也没有。...tap 事件的判定一个正确的 tap 事件应当满足一下条件:用户手指从屏幕移开时触发不能在用户移动手指时触发(防止和滚动、拖拽事件的冲突)多个手指同时触摸屏幕时不能触发不应该触发 click 事件具体实现代码可以参考

1.7K20

JS中的touch事件与canvas绘图

Touch事件分类 touchstart:当手指触摸屏幕时触发。...不管有多少个手指放在了屏幕上,只要再触摸一下屏幕就会触发 touchmove:当手指在屏幕上滑动的时候触发该是事件,在这期间可以通过event.preventDefault()来阻止滚动 touchend...用两个手指同时接触屏幕,此时changedTouches有两个值,每一个手指的触摸点都有一个值 手指滑动时,三个值都会发生变化 一个手指离开屏幕,touches和targetTouches中对应的元素会同时移除...手指都离开屏幕之后,touches和targetTouches中将不会再有值, changedTouches还会有一个值,此值为最后一个离开屏幕的手指的接触点。...,返回鼠标指针相对于文档的水平坐标 pageY 触发鼠标事件时,返回鼠标指针相对于文档的垂直坐标 screenX 触发事件时,返回鼠标指针相对于屏幕的水平坐标 screenY 触发事件时,返回鼠标指针相对于屏幕的垂直坐标

7.6K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Android自定义系列——14.MotionEvent

    单点触控 事件 简介 ACTION_DOWN 手指 初次接触到屏幕 时触发。 ACTION_MOVE 手指 在屏幕上滑动 时触发,会多次触发。 ACTION_UP 手指 离开屏幕 时触发。...如果仅仅是单击(手指按下再抬起),不会触发 ACTION_MOVE。...第一次按下的手指特殊处理作为主指针,之后按下的手指作为辅助指针,然后随之衍生出来了以下事件(注意增加的事件和事件简介的变化): 事件 简介 ACTION_DOWN 第一个 手指 初次接触到屏幕 时触发。...ACTION_MOVE 手指 在屏幕上滑动 时触发,会多次触发。 ACTION_UP 最后一个 手指 离开屏幕 时触发。...ACTION_SCROLL 滚轮滚动,可以触发水平滚动(AXIS_HSCROLL)或者垂直滚动(AXIS_VSCROLL) 注意: 1、这些事件类型是 安卓4.0 (API 14) 才添加的。

    2K10

    移动端滚动研究

    不能实时触发 | | android | 实时触发| 实时触发 | | ios wkwebview内核 | 实时触发| 实时触发 | 不能实时触发表现:只在手指触摸的屏幕上一直滑动时和滚动停止的那一刻才触发...模拟滚动:最典型的例子就是iscroll了,原理一般有两种: 监听滚动元素的touchmove事件,当事件触发时修改元素的transform属性来实现元素的位移,让手指离开时触发touchend事件,然后采用...监听滚动元素的touchmove事件,当事件触发时修改元素的transform属性来实现元素的位移,让手指离开时触发touchend事件,然后给元素一个css的animation,并设置好duration...和function来实现手指离开时的一段惯性距离。...第二种方案相比第一种要劣势一些,区别在于手指离开时,采用的时css的animation来实现惯性滚动,所以无法直接触发惯性滚动过程中的onscroll事件,只有在animation结束时才可以借助animationend

    3.2K20

    移动端app开发问题及理解

    ondragover 元素在有效拖放目标上正在被拖动时运行的脚本 ondragstart 在拖动操作开端运行的脚本 ondrop 当被拖元素正在被拖放是运行的脚本 onmousewheel 当鼠标滚轮整被滚动时...onscroll 元素滚动条被滚动时 移动端事件有 click 单击事件 类似于pc端click,移动端中,连续click触发有200ms-300ms的延迟 touch 触摸类事件 touchstart...手指触摸到屏幕触发 touchmove 手指在屏幕上移动触发 touchend 手指离开屏幕触发 touchcancel 可由系统进行的触发,比如手指触摸屏幕时,突然alert了,或者系统中其他打断了...touch行为可触发 tap触碰类事件 一般用于代替click事件 tap 手指碰一下屏幕触发 longTap 手指长按屏幕触发 singleTap 手指碰一下屏幕触发 doubleTap 手指双击屏幕触发...swip滑动类事件 swipe 手指在屏幕上滑动触发 swipeLeft 手指在屏幕上左滑触发 swipeRight 手指在屏幕上右滑触发 swipeUp 手指在屏幕上上滑触发 swipeDown

    3.8K10

    10-移动端开发教程-移动端事件

    最基本的touch事件包括4个事件: touchstart: 当在屏幕上按下手指时触发 touchmove: 当在屏幕上移动手指时触发 touchend: 当在屏幕上抬起手指时触发...不会包括左边的滚动距离。 5. clientY 触摸点相对于浏览器的 viewport上边缘的 y 坐标。不会包括上边的滚动距离。...tap: 手指碰一下屏幕会触发 longTap: 手指长按屏幕会触发 singleTap: 手指碰一下屏幕会触发 doubleTap: 手指双击屏幕会触发 5.2 swipe类事件 滑动事件,有swipe...swipe:手指在屏幕上滑动时会触发 swipeLeft:手指在屏幕上向左滑动时会触发 swipeRight:手指在屏幕上向右滑动时会触发 swipeUp:手指在屏幕上向上滑动时会触发 swipeDown...:手指在屏幕上向下滑动时会触发 ?

    6.4K70

    10-移动端开发教程-移动端事件

    最基本的touch事件包括4个事件: touchstart: 当在屏幕上按下手指时触发 touchmove: 当在屏幕上移动手指时触发 touchend: 当在屏幕上抬起手指时触发 touchcancel...一次完整的touch事件的触发顺序和过程 2.5 touchcancel事件 ​ 当触点由于某些原因被中断时触发。...不会包括左边的滚动距离。 5. clientY 触摸点相对于浏览器的 viewport上边缘的 y 坐标。不会包括上边的滚动距离。...tap: 手指碰一下屏幕会触发 longTap: 手指长按屏幕会触发 singleTap: 手指碰一下屏幕会触发 doubleTap: 手指双击屏幕会触发 5.2 swipe类事件 滑动事件,有swipe...swipe:手指在屏幕上滑动时会触发 swipeLeft:手指在屏幕上向左滑动时会触发 swipeRight:手指在屏幕上向右滑动时会触发 swipeUp:手指在屏幕上向上滑动时会触发 swipeDown

    6.8K80

    2016.06 第三周 群问题分享

    在iOS及Android会占据空间大小,而在PC端Chrome浏览器是不会占据任何空间 移动端有哪些touch事件 2016.06.20~2016.06.24 核心内容 touch事件 参考答案 当用户手指放在移动设备的屏幕上滑动会触发的...不管当前有多少只手指 touchmove——当手指在屏幕上滑动时连续触发。...通常我们为了防止页面的滚动,会调用event的preventDefault()可以阻止默认事件的发生,达到阻止页面滚动的效果 touchend——当手指离开屏幕时触发 touchcancel——系统停止跟踪触摸时会触发...不管当前有多少只手指 MSPointerMove——当手指在屏幕上滑动时连续触发。...通常我们再滑屏页面,会调用css的html{-ms-touch-action: none;}可以阻止默认情况的发生:阻止页面滚动 MSPointerUp——当手指离开屏幕时触发 如何用jQuery实现两个

    98790

    移动端轮播图笔记

    触屏事件可以相应用户手指对屏幕或者触控板操作 常见的触屏事件: 1.touchstart:手指触摸到一个DOM元素时触发 2.touchmove:手指在一个DOM元素上滑动时触发 3.touchend:...手指从一个DOM元素上移开时触发 1.2触摸事件对象(TochEvent) TouchEvent是一类描述手指在触摸平面(触摸屏、触摸板等)的状态变化的事件。...(2)移动手指touchmove:计算手指的滑动距离,并且移动盒子 (3)离开手指touchend 注意:手指移动也会触发滚动屏幕所以这里要阻止默认的屏幕滚动e.preventDefault...2.页面盛满屏幕,盒子宽度与屏幕一致 100% 3.让盒子的内容宽高width/height包含padding与border,避免出现横向滚动条...();//阻止滚动屏幕的行为 }); //手指离开,根据移动距离去判断是回弹还是播放上一张下一张 ul.addEventListener("touchend", function

    2.5K21

    原生JS实现移动端滑动反弹

    1、touchStart当手指触碰到屏幕的时候触发 2、touchmove当手指在屏幕上不断移动的时候触发 3、touchend当手指离开屏幕的时候触发 Touch 事件触发的 Event 对象 //...手指触碰到屏幕时触发 element.addEventListener('touchstart', function (e) {    // 打印的事件对象    console.log(e);...事件的时候, targetTouches、 touches对象是不能返回离开屏幕时的手指信息,只有 changedTouches对象能返回。...clientY:73    // 触摸点相对于浏览器的 viewport 上边缘的 Y 坐标,不会包括上边的滚动距离。 screenX:2202  // 触摸点相对于屏幕左边缘的 x 坐标。...我们限定只要手指离开时,上一次的滑动距离加上本次的距离 >0的时候,就让它触发反弹,并且反弹回 0点的位置,也就是两次滑动的距离和 =0。 ?

    10.4K20

    HTML5移动端开发的常用触摸事件

    触摸事件(touch)会在用户手指放在屏幕上面的时候、在屏幕上滑动的时候或者是从屏幕上移开的时候出发。...下面具体说明:   touchstart事件:当手指触摸屏幕时候触发,即使已经有一个手指放在屏幕上也会触发。   touchmove事件:当手指在屏幕上滑动的时候连续地触发。...在这个事件发生期间,调用preventDefault()事件可以阻止滚动。   touchend事件:当手指从屏幕上离开的时候触发。   touchcancel事件:当系统停止跟踪触摸的时候触发。...(返回当事件被触发时,鼠标指针的水平坐标)、clientY(返回当事件触发时,鼠标指针的垂直坐标)、screenX(当某个事件被触发时,鼠标指针的水平坐标)和screenY(返回当某个事件被触发时,鼠标指针的垂直坐标...pageX/pageX/clientX/clientY/screenX/screenY:一个数值,动作在屏幕上发生的位置(page包含滚动距离,client不包含滚动距离,screen则以屏幕为基准)。

    1.7K10

    挥别web移动端开发差异和经典坑

    . auto: 使用普通滚动, 当手指从触摸屏上移开,滚动会立即停止。...解决: fastclick可以解决在手机上点击事件的300ms延迟 zepto的touch模块,tap事件也是为了解决在click的延迟问题 iOS上拉边界下拉出现空白,安卓无 描述:手指按住屏幕下拉,...手指按住屏幕上拉,底部多出一块白色区域。安卓无此特性。 在 iOS 中,手指按住屏幕上下拖动,会触发 touchmove 事件。...如果该元素已经在浏览器窗口的可见区域内,则不会发生滚动。...描述:在使用oninput监控输入框内容变化时,我们期望仅在value值变化时,才触发oninput事件,而在中文输入下,未选词时的按键也会触发oninput事件。

    2.9K20

    手撸移动端轮播图(内含源码)

    注意,我们判断条件是要等到图片滚动完毕再去判断,就是过渡完成后判断 此时需要添加检测过渡完成事件 transitionend 判断条件:如果索引号等于 3 说明走到最后一张图片,此时 索引号要复原为...,导致不会触发这个事件 focus_img.addEventListener('transitionend', function () { /*如果index=...1)手指按下,停止自动轮播,手指离开屏幕继续开启自动轮播 2)实现轮播图(focus_img)随着手指的移动而移动 3)手指离开屏幕后,判断用户手指的移动距离...,根据距离判断是切换轮播图还是回弹轮播图 4)如果用户只是按下手指,并没有移动,然后手指就离开屏幕,可以不执行第三步。...:如何判断: 只要用户移动手指就会触发touchmove事件,如果用户没有移动手指,不会触发这个事件 */ // 声明变量,存储手指的按下时的位置

    1.4K00

    第134天:移动web开发的一些总结(二)

    自定义tao事件原理: 在touchstart、touchend的记录时间、手指位置,在touchend时进行比较,如果手指位置为同一位置(或允许移动一个非常小的位移值)且时间间隔较短(一般认为是200ms...touchstart:手指触摸屏幕触发(已经有手指放屏幕上不会出发) touchmove:手指在屏幕上滑动,连续触发 touchend:手指离开屏幕时触发 touchcancel:系统取消touch时候触发...(不常用)eg:滑动页面时来了一个电话或者其他系统事件 除常见的事件属性外,触摸事件包含专有的触摸属性: touches:跟踪触摸操作的touch对象数组 targetTouches:特定事件目标的touch...当一个css3动画结束时,我们可以监听相关事件AnimationEnd,比如对于webkit来说,是webkitAnimationEnd。...8)2048制作过程中遇到的bug:(见9(2)touch基础事件BUG) // 手机上手指识别无用,chrome19827号错误:touchevent不被触发。

    1.8K10

    简述android触屏事件的处理_移动端touch事件有哪些

    触屏事件类型 按照动作来分,可以将触屏事件可以分为以下三类 手指按到屏幕上 手指在屏幕上移动 手指离开屏幕 其中手指按到屏幕上和手指离开屏幕一定是成对出现的,在这中间会出现不定次数的手指在屏幕上移动的事件...对多点触屏事件,则是从第一个手指按到屏幕上开始,到最后一个手指离开屏幕为止。 一个触屏事件序列第一个事件一定是手指按到屏幕上,最后一个事件一定是手指离开屏幕。...事件类型常量 含义说明 ACTION_DOWN 当手指接触屏幕时产生此事件,在多点触摸时,只有第一个手指接触屏幕时才会产生此事件,中间其他手指接触屏幕不会产生此事件。...ACTION_UP 当手指离开屏幕时产生此事件,在多点触摸时,只有最后一个手指(这个手指并不一定是产生ACTION_DOWN事件的那个手指)离开屏幕时才会产生此事件,中间其他手指离开屏幕不会产生此事件。...ACTION_POINTER_UP 同样只有在多点触摸时才会产生此事件,在一个触屏事件序列中,除最后一个离开屏幕的手指外,其他手指离开屏幕时会产生此事件。

    1.3K10

    触屏事件

    touch:触摸事件 常用触摸事件如下 事件 描述 touchstart 手指触摸到dom元素时触发 touchmove 手指在dom元素上滑动时触发 touchend 手指离开dom元素时触发 触摸事件对象...触摸板等)的状态变化的事件,这类事件用于描述一个或多个触点,使开发者可以检测触点的移动,触点的增加和减少等等 上述三个事件都有各自的事件对象 touchstart常用对象列表 触摸列表 描述 touches...正在触摸屏幕的所有手指的一个列表 targetTouches 正在触摸当前dom元素上的手指的一个列表 changedTouches 手指状态发生改变的列表,从无到有,从有到无变化 如targetTouches...[0]第一个手指触摸的相关信息 案例实现可以拖动的div <!...pageY - startY; this.style.transform = 'translate('+moveX+'px,'+moveY+'px)' //手指移动会触发滚动屏幕

    77110

    教你实现一个悬浮可拖动并在滑动页面时会自动收缩的vue侧边组件按钮

    touchstart touchmove touchend touchstart事件:当手指触摸屏幕时候触发,即使已经有一个手指放在屏幕上也会触发。...touchmove事件:当手指在屏幕上滑动的时候连续地触发。在这个事件发生期间,调用preventDefault()事件可以阻止滚动。 touchend事件:当手指从屏幕上离开的时候触发。...document.documentElement.clientWidth - 70; }else{ this.left = 15 } }) }) // 监听scroll事件获取滚动距离...watch: { scrollTop(newValue, oldValue){} } ...... if(this.oldScrollTop == oldValue) { //每次滚动开始时oldScrollTop...{ this.left = this.left + 40 } } 复制代码 结束滑动 结束滑动时判断滑动距离是否等于页面水平滚动的像素数,等于则代表了停止滑动,这时判断一下当前组件在页面左侧还是右侧并调整相关的距离参数

    5.2K40
    领券