Ir al Contenido Principal

tap

Performs a tap gesture on:

  • or the given element. It will automatically scroll if it can't be found.
  • or the screen on a mobile device by providing x and y coordinates

Internally it uses:

  • Element tap:
    • the click command for Web environments (Chrome/Safari browsers, or hybrid apps)
    • the Android mobile: clickGesture or iOS mobile: tap for Natives apps, including the scrollIntoView command for automatic scrolling
  • Screen tap:

This difference makes the tap command a more reliable alternative to the click command for mobile apps.

For Native Apps, this command differs from the click command as it will automatically swipe to the element using the scrollIntoView command, which is not supported for native apps with the click command. In hybrid apps or web environments, automatic scrolling is supported for both click and tap commands.

For Screen taps

If you want to tap on a specific coordinate on the screen and you use a screenshot to determine the coordinates, remember that the the coordinates for iOS are based on the device's screen size, and not the screenshot size. The screenshot size is larger due to the device pixel ratio. The average device pixel ratio until the iPhone 8 and the current iPads is 2, for iPhones from the iPhone X the ratio is 3. This means that the screenshot size is 2 or 3 times larger than the device's screen size which means that ff you find the coordinates on the screenshot, divide them by the device pixel ratio to get the correct screen coordinates. For example:

const screenshotCoordinates = { x: 600, y: 900 };
const dpr = 3; // Example for iPhone 16
const screenCoordinates = {
x: screenshotCoordinates.x / dpr,
y: screenshotCoordinates.y / dpr
};
await browser.tap(screenCoordinates);
Parameters
NameTypeDetails
options
optional
TapOptionsTap options (optional)
Element tap options
options.x
optional
numberNumber (optional, mandatory if y is set)
Only for SCREEN tap, not for ELEMENT tap
options.y
optional
numberNumber (optional, mandatory if x is set)
Only for SCREEN tap, not for ELEMENT tap
Screen tap options
options.direction
optional
stringCan be one of down, up, left or right, default is down.
Only for ELEMENT tap, not for SCREEN tap
MOBILE-NATIVE-APP-ONLY
options.maxScrolls
optional
numberThe max amount of scrolls until it will stop searching for the element, default is 10.
Only for ELEMENT tap, not for SCREEN tap
MOBILE-NATIVE-APP-ONLY
options.scrollableElement
optional
ElementElement that is used to scroll within. If no element is provided it will use the following selector for iOS -ios predicate string:type == "XCUIElementTypeApplication" and the following for Android //android.widget.ScrollView'. If more elements match the default selector, then by default it will pick the first matching element.
Only for ELEMENT tap, not for SCREEN tap
MOBILE-NATIVE-APP-ONLY
Examples
element.tap.example.js
it('should be able to tap an on element', async () => {
const elem = $('~myElement')
// It will automatically scroll to the element if it's not already in the viewport
await elem.tap()
})

element.tap.scroll.options.example.js
it('should be able to swipe right 3 times in a custom scroll areas to an element and tap on the element', async () => {
const elem = $('~myElement')
// Swipe right 3 times in the custom scrollable element to find the element
await elem.tap({
direction: 'right',
maxScrolls: 3,
scrollableElement: $('#scrollable')
})
})

screen.tap.example.js
it('should be able to tap on screen coordinates', async () => {
await browser.tap({ x: 200, y: 400 })
})

Welcome! How can I help?

WebdriverIO AI Copilot