Passer au contenu principal

scrollIntoView

Scroll element into viewport for Desktop/Mobile Web AND Mobile Native Apps.

information

Scrolling for Mobile Native Apps is done based on the mobile swipe command.

Usage
$(selector).scrollIntoView({ behavior, block, inline, direction, maxScrolls, duration, scrollableElement, percent })
Parameters
NameTypeDetails
optionsobject, booleanoptions for Element.scrollIntoView(). Default for desktop/mobile web:
{ block: 'start', inline: 'nearest' }
Default for Mobile Native App
{ maxScrolls: 10, scrollDirection: 'down' }
Desktop/Mobile Web Only
options.behavior
optional
stringSee MDN Reference.
WEB-ONLY (Desktop/Mobile)
options.block
optional
stringSee MDN Reference.
WEB-ONLY (Desktop/Mobile)
options.inline
optional
stringSee MDN Reference.
WEB-ONLY (Desktop/Mobile)
Mobile Native App Only
options.direction
optional
stringCan be one of down, up, left or right, default is up.
MOBILE-NATIVE-APP-ONLY
options.maxScrolls
optional
numberThe max amount of scrolls until it will stop searching for the element, default is 10.
MOBILE-NATIVE-APP-ONLY
options.duration
optional
numberThe duration in milliseconds for the swipe. Default is 1500 ms. The lower the value, the faster the swipe.
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.
MOBILE-NATIVE-APP-ONLY
options.percent
optional
numberThe percentage of the (default) scrollable element to swipe. This is a value between 0 and 1. Default is 0.95.
NEVER swipe from the exact top|bottom|left|right of the screen, you might trigger for example the notification bar or other OS/App features which can lead to unexpected results.
MOBILE-NATIVE-APP-ONLY
Examples
desktop.mobile.web.scrollIntoView.js
it('should demonstrate the desktop/mobile web scrollIntoView command', async () => {
const elem = await $('#myElement');
// scroll to specific element
await elem.scrollIntoView();
// center element within the viewport
await elem.scrollIntoView({ block: 'center', inline: 'center' });
});

mobile.native.app.scrollIntoView.js
it('should demonstrate the mobile native app scrollIntoView command', async () => {
const elem = await $('#myElement');
// scroll to a specific element in the default scrollable element for Android or iOS for a maximum of 10 scrolls
await elem.scrollIntoView();
// Scroll to the left in the scrollable element called '#scrollable' for a maximum of 5 scrolls
await elem.scrollIntoView({
direction: 'left',
maxScrolls: 5,
scrollableElement: $('#scrollable')
});
});

Welcome! How can I help?

WebdriverIO AI Copilot