ScrollObserver thresholds
Determines the points at which actions are triggered based on the scrolling position of a target element within a container.
Thresholds are defined with the enter
and leave
properties of the onScroll()
parameters Object
.
animate('.square', {
x: 100,
autoplay: onScroll({
container: '.container',
target: '.section',
axis: 'y',
┌──────────────────────────┐
│ enter: 'bottom top', ├─ Thresholds
│ leave: 'top bottom', │
└──────────────────────────┘
sync: true,
onEnter: () => {},
onLeave: () => {},
onUpdate: () => {},
})
});
The conditions that determine when an element enters or leaves the viewport are specified by comparing two pairs of values: the target and container start
and end
values.
┌────────────────────────────────┐- Container Start
│ │
│ Container │
│ │
│ ┌──────────┐----------│- Target Start
│ │ │ │
│ │ Target │ │
└────────────────────────────────┘- Container End
│ │
└──────────┘------------ Target End
Different syntaxes
Conditions can be written with the following syntaxes:
Object
onScroll({
// Enters when the top of the target meets the bottom of the container
enter: { target: 'top', container: 'bottom' },
// Leaves when the bottom of the target meets the top of the container
leave: { target: 'bottom', container: 'top' }
});
Container value String
The container value can be passed directly and the target value defaults to 'start'
for enter and 'end'
for leave.
onScroll({
// Enters when the top of the target meets the bottom of the container
enter: 'bottom',
// Leaves when the bottom of the target meets the top of the container
leave: 'top'
});
Container and target value shorthand String
onScroll({
// Enters when the bottom of the container meets the top of the target
enter: 'bottom top',
// Leaves when the top of the container meets the bottom of the target
leave: 'top bottom',
});
Default enter
'end start'
Default leave
'start end'
In this section