Bug 270064

Summary: [css-scroll-snap] Ignores scroll-snap-type: mandatory on JS-triggered scrolling
Product: WebKit Reporter: Casey Carroll <casey.r.carroll>
Component: ScrollingAssignee: Nobody <webkit-unassigned>
Status: NEW    
Severity: Normal CC: karlcow, nmouchtaris, rik, simon.fraser, webkit-bug-importer
Priority: P2 Keywords: BrowserCompat, HasReduction, InRadar
Version: Safari 17   
Hardware: All   
OS: All   
See Also: https://bugs.webkit.org/show_bug.cgi?id=241737
Attachments:
Description Flags
Video of scenario described in bug report none

Casey Carroll
Reported 2024-02-25 21:25:39 PST
Created attachment 470046 [details] Video of scenario described in bug report WebKit ignores a scroll container's scroll-snap-type: mandatory and child's scroll-snap-align when scrolling is invoked via JS. i.e. Element.scrollBy(), Element.scrollTo(). Given a 300px container with 100% width children overflowing in the inline direction, each with scroll-snap-align set, When container.scrollBy(150, 0) is called the container scrolls 150px and does not snap to the next child nor return to the previous child As a result, The scroller's x coordinates stick exactly at 150px between the two items despite the scroll-snap configuration. Chrome and Firefox will snap to the next item, even if the x-coord parameter is set to a minimum, 1 pixel. Essentially, when a scrolling function is called in WebKit, it scrolls to the exact coordinates but does not apply scroll snapping. This bug does not apply to scrolling initiated by touch, trackpad and mouse gestures. Example: https://codepen.io/caseycarroll42/pen/poYvOJm
Attachments
Video of scenario described in bug report (305.76 KB, video/quicktime)
2024-02-25 21:25 PST, Casey Carroll
no flags
Anthony Ricaud
Comment 1 2024-02-26 03:54:38 PST
Radar WebKit Bug Importer
Comment 2 2024-03-03 21:26:13 PST
Karl Dubost
Comment 3 2024-03-05 01:15:26 PST
Yes, I think Anthony is right. I let Simon duplicates it if he thinks that's the case.
Anthony Ricaud
Comment 4 2024-03-05 08:16:16 PST
Taking another look at bug 241737, I wouldn't say they are duplicates anymore. This bug is using `scrollBy()` and `scrollTo()` and not getting the snapping effect wanted. Whereas bug 241737 is using `scrollLeft` and getting an undesired snapping effect.
Note You need to log in before you can comment on or make changes to this bug.