• 移动端touch事件


    当用户手指放在移动设备在屏幕上滑动会触发的touch事件

    webkit:

    • touchstart——当手指触碰屏幕时候发生。不管当前有多少只手指
    • touchmove——当手指在屏幕上滑动时连续触发。通常我们再滑屏页面,会调用event的preventDefault()可以阻止默认情况的发生:阻止页面滚动
    • touchend——当手指离开屏幕时触发
    • touchcancel——系统停止跟踪触摸时候会触发。例如在触摸过程中突然页面alert()一个提示框,此时会触发该事件,这个事件比较少用

    TouchEvent

    • touches:屏幕上所有手指的信息
    • targetTouches:手指在目标区域的手指信息
    • changedTouches:最近一次触发该事件的手指信息
    • touchend时,touches与targetTouches信息会被删除,changedTouches保存的最后一次的信息,最好用于计算手指信息

    参数信息(changedTouches[0])

    • clientX、clientY在显示区的坐标
    • target:当前元素

    参考:https://developer.mozilla.org/en-US/docs/Web/API/TouchEvent

    winphone 8:

    • MSPointerDown——当手指触碰屏幕时候发生。不管当前有多少只手指
    • MSPointerMove——当手指在屏幕上滑动时连续触发。通常我们再滑屏页面,会调用css的html{-ms-touch-action: none;}可以阻止默认情况的发生:阻止页面滚动
    • MSPointerUp——当手指离开屏幕时触发

     

    触摸事件的响应顺序

    1、ontouchstart 

    2、ontouchmove 

    3、ontouchend 

    4、onclick

    移动端click屏幕产生200-300 ms的延迟响应

    移动设备上的web网页是有300ms延迟的,玩玩会造成按钮点击延迟甚至是点击失效。

    苹果发布首款iphone上ios系统搭载的safari为了将适用于PC端上大屏幕的网页能比较好的展示在手机端上,使用了双击缩放(double tap to zoom)的方案,比如你在手机上用浏览器打开一个PC上的网页,你可能在看到页面内容虽然可以撑满整个屏幕,但是字体、图片都很小看不清,此时可以快速双击屏幕上的某一部分,你就能看清该部分放大后的内容,再次双击后能回到原始状态。

    双击缩放是指用手指在屏幕上快速点击两次,iOS 自带的 Safari 浏览器会将网页缩放至原始比例。

    原因就出在浏览器需要如何判断快速点击上,当用户在屏幕上单击某一个元素时候,例如跳转链接<a href="#"></a>,此处浏览器会先捕获该次单击,但浏览器不能决定用户是单纯要点击链接还是要双击该部分区域进行缩放操作,所以,捕获第一次单击后,浏览器会先Hold一段时间touch,如果在touch时间区间里用户未进行下一次点击,则浏览器会做单击跳转链接的处理,如果touch时间里用户进行了第二次单击操作,则浏览器会禁止跳转,转而进行对该部分区域页面的缩放操作。那么这个时间区间是有多少呢?

    在IOS safari下,大概为300毫秒。这就是延迟的由来。造成的后果用户纯粹单击页面,页面需要过一段时间才响应,给用户慢体验感觉,对于web开发者来说是,页面js捕获click事件的回调函数处理,需要300ms后才生效,也就间接导致影响其他业务逻辑的处理。

    解决方案:

    • fastclick可以解决在手机上点击事件的300ms延迟
    • zepto的touch模块,tap事件也是为了解决在click的延迟问题

    ios系统中元素被触摸时产生的半透明灰色遮罩怎么去掉

    ios用户点击一个链接,会出现一个半透明灰色遮罩, 如果想要禁用,可设置-webkit-tap-highlight-color的alpha值为0,也就是属性值的最后一位设置为0就可以去除半透明灰色遮罩。

    a,button,input,textarea{-webkit-tap-highlight-color: rgba(0,0,0,0;)}

    部分android系统中元素被点击时产生的边框怎么去掉

    android用户点击一个链接,会出现一个边框或者半透明灰色遮罩, 不同生产商定义出来额效果不一样,可设置-webkit-tap-highlight-color的alpha值为0去除部分机器自带的效果。

    a,button,input,textarea{
    -webkit-tap-highlight-color: rgba(0,0,0,0;)
    -webkit-user-modify:read-write-plaintext-only; 
    }

    -webkit-user-modify有个副作用,就是输入法不再能够输入多个字符

    另外,有些机型去除不了,如小米2

    对于按钮类还有个办法,不使用a或者input标签,直接用div标签。

    wp系统a、input标签被点击时产生的半透明灰色背景怎么去掉

    <meta name="msapplication-tap-highlight" content="no">
    --任何组织或个人分享、转载本博客内容,请务必以链接方式注明出处:来自博客园--下雨天的太阳(http://www.cnblogs.com/doomjx/)--
    --请勿以任何形式修改内容(包括文字和图片)--
  • 相关阅读:
    (兼容IE8)的渐变
    左侧固定,右侧自适应,两列等高并且自适应的第二种办法
    左侧定宽,右侧自适应,两列布局且等高
    下拉框重写
    在页面中输出当前客户端时间
    用哈希表去数组重复项,有详细注释
    求数组最大值、求和、乘法表、取整
    类似新浪微博输入字符计数的效果
    将博客搬至CSDN
    Mysql常用操作
  • 原文地址:https://www.cnblogs.com/doomjx/p/5773249.html
Copyright © 2020-2023  润新知