touch-action 解决移动端300ms延迟问题

时间:2023-01-04 14:25:25

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

移动端300ms延迟问题一直都是h5APP的痛点, 有很多库或者方法都可以解决, 比如用onstouchstart和ontouchend已经 ontouchmove来实现点击, 这样代码会多写很多, 不如一个onclick来的直接, 也有用库来解决的, 比如zepto.js, 来书写点击事件, 但是就为了一个点击事件, 要引入一个库, 代价还是有点大的

CSS3为了解决这个难题, 特意创造了一个属性, 就是touch-action, 只要要在body上写上这个属性, 300ms的延迟问题就解决了, 简直是 so easy! 别担心兼容问题, 现在几乎都是智能设备, 移动端都是支持的

其实touch-action还有很多属性

touch-action 解决移动端300ms延迟问题

1. auto

当点击事件发生在元素上时, 由浏览器决定执行拿些操作, 比如对viewport进行平滑, 缩放等

2. none

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

3. pan-x

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

4. manipulation

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

5. pan-left, pan-right, pan-up, pan-down

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

6. pinch-zoom

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