--- title: touch-action slug: Web/CSS/touch-action translation_of: Web/CSS/touch-action ---
Css-свойство touch-action указывает как элемент будет управляться через тачскрин (например, при помощи возможности приближения (zooming), встроенной в браузер).
/* Keyword values */ touch-action: auto; touch-action: none; touch-action: pan-x; touch-action: pan-left; touch-action: pan-right; touch-action: pan-y; touch-action: pan-up; touch-action: pan-down; touch-action: pinch-zoom; touch-action: manipulation; /* Global values */ touch-action: inherit; touch-action: initial; touch-action: unset;
По умолчанию, жесты панорамирование, прокрутка и сужающий обрабатываются исключительно браузером. Приложение, использующие {{domxref("Pointer_events", "Pointer events", "", 1)}} получит событие {{domxref("HTMLElement/pointercancel_event", "pointercancel")}}, когда браузер начнет обрабатывать тач жест. Явно указывая жесты обрабатываемые браузером, приложение может иметь свое поведение для оставшихся жестов благодаря прослушиванию событий {{domxref("HTMLElement/pointermove_event", "pointermove")}} и {{domxref("HTMLElement/pointerup_event", "pointerup")}}. Applications using {{domxref("Touch_events", "Touch events", "", 1)}} disable the browser handling of gestures by calling {{domxref("Event.preventDefault","preventDefault()")}}, but should also use touch-action
to ensure the browser knows the intent of the application before any event listeners have been invoked.
When a gesture is started, the browser intersects the touch-action values of the touched element and all its ancestors up to the one that implements the gesture (in other words, the first containing scrolling element). This means that in practice, touch-action is typically applied only to individual elements which have some custom behavior, without needing to specify touch-action explicitly on any of that element's descendants. After a gesture has started, changes to touch-action values will not have any impact on the behavior of the current gesture.
The touch-action
property may be specified as either:
auto
, none
, manipulation
, orpan-x
, pan-left
, pan-right
, and/or one of the keywords pan-y
, pan-up
, pan-down
, plus optionally the keyword pinch-zoom
.auto
none
pan-x
pan-y
manipulation
pan-left
, pan-right,pan-up,pan-down
{{experimental_inline}}pinch-zoom
{{csssyntax}}
The most common usage is to disable all gestures on an element (and its non-scrollable descendants) that provides its own dragging and zooming behavior – such as a map or game surface.
#map { touch-action: none; }
Another common pattern is that of an image carousel which uses pointer events to handle horizontal panning, but doesn't want to interfere with vertical scrolling or zooming of the document.
.image-carousel { width: 100%; height: 150px; touch-action: pan-y pinch-zoom; }
touch-action is also often used to completely disable the delay of click events caused by support for the double-tap to zoom gesture.
html { touch-action: manipulation; }
Specification | Status | Comment |
---|---|---|
{{SpecName('Compat', '#touch-action', 'touch-action')}} | {{Spec2('Compat')}} | Added pinch-zoom property value. |
{{SpecName('Pointer Events 2', '#the-touch-action-css-property', 'touch-action')}} | {{Spec2('Pointer Events 2')}} | Added pan-left , pan-right , pan-up , pan-down property values. |
{{SpecName('Pointer Events', '#the-touch-action-css-property', 'touch-action')}} | {{Spec2('Pointer Events')}} | Initial definition |
{{ CompatibilityTable }}
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|---|
Basic support | {{CompatChrome(36.0)}} | {{CompatVersionUnknown}} | {{CompatGeckoDesktop("52.0")}}[1] | 10.0{{property_prefix("-ms")}}[2] 11.0 |
{{CompatOpera(23)}} | {{CompatNo}}[4] |
pan-up , pan-down , pan-left , pan-right |
{{CompatChrome(55.0)}} | {{CompatNo}} | {{CompatNo}}[5] | {{CompatUnknown}} | {{CompatOpera(42)}} | {{CompatNo}}[4] |
pinch-zoom |
{{CompatChrome(56.0)}} | {{CompatVersionUnknown}} | {{CompatNo}}[5] | 10.0{{property_prefix("-ms")}}[2] 11.0 |
{{CompatOpera(43)}} | {{CompatNo}}[4] |
Feature | Android Webview | Chrome for Android | Edge | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|---|
Basic support | {{CompatChrome(36.0)}} | {{CompatChrome(36.0)}} | {{CompatVersionUnknown}} | {{CompatGeckoMobile("52.0")}}[1] | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | 9.1 [3] |
pan-up , pan-down , pan-left , pan-right |
{{CompatChrome(55.0)}} | {{CompatChrome(55.0)}} | {{CompatNo}} | {{CompatNo}}[5] | {{CompatNo}} | {{CompatOperaMobile(42)}} | {{CompatNo}} |
pinch-zoom |
{{CompatChrome(56.0)}} | {{CompatChrome(56.0)}} | {{CompatVersionUnknown}} | {{CompatNo}}[5] | {{CompatUnknown}} | {{CompatOperaMobile(43)}} | {{CompatNo}} |
[1] This property (Level 1 keywords only) is implemented since Firefox 29, but is hidden behind the layout.css.touch_action.enabled
preference. Starting in Firefox Nightly 50, it is enabled by default when running in nightly builds only. It is currently on track to be released in Firefox 52, see {{bug(1244402)}}.
[2] IE10+ additionally supports the non-standard values pinch-zoom, double-tap-zoom, cross-slide-x and cross-slide-y.
[3] Only supports the manipulation and auto values in iOS.
[4] See {{webkitbug("133112")}}.
[5] See {{bug(1285685)}}.