移动端300毫秒延迟的问题

一。产生原因

  苹果手机双击放大的功能,是这样设置的:如果在第一次点击之后300ms之内,没有下一次点击,认为是单击;否则认为是双击

二。解决方法

  (1)faskclick

         引入后,初始化    fastclick.attach(document.body)

      (2)用纯css3属性解决移动端300毫秒延迟的问题

    touch-action:manipulation ;可以有效解决移动端300ms延迟的问题;

    只要早body上面写这个属性:body{ touch-action : manipulation }

    * touch-action 的其他属性

      -auto: 当点击事件发生在元素的时候,由浏览器决定执行哪些操作

      -none:当点击事件发生在元素时,不进行任何操作

      -pan-x:启用单指水平平移手势, 可以与 pan-y, pan-up, pan-down和pinch-zoom组合使用

      -manipulation: 浏览器只允许进行滚动和持续缩放操作,任何其它被auto值支持的行为不被支持。启用平移和缩小缩放手势,但禁用其他非标准手势,例如双击以进行缩放。 禁用双击可缩放功能可减少浏览器在用户点击屏幕时延迟生成点击事件的需要。 这是“pan-x pan-y pinch-zoom”(为了兼容性本身仍然有效)的别名

      -pan-left, pan-right, pan-up, pan-down:启用以指定方向滚动开始的单指手势。 一旦滚动开始,方向可能仍然相反。 请注意,滚动“向上”(pan-up)意味着用户正在将其手指向下拖动到屏幕表面上,同样 pan-left 表示用户将其手指向右拖动。 多个方向可以组合,除非有更简单的表示(例如,“pan-left pan-right”无效,因为“pan-x”更简单,而“pan-left pan-down”有效)。

      -pinch-down: 启用多手指平移和缩放页面。 这可以与任何平移值组合

  

 

posted @ 2018-05-30 15:32  crystal_wei  阅读(585)  评论(0编辑  收藏  举报