CSS Scroll Snap
- CRCSS technique that allows customizable scrolling experiences like pagination of carousels by setting defined snap positions.
Chrome
- ❌ 4 - 65: Not supported
- ❌ 66 - 68: Disabled by default
- ✅ 69 - 127: Supported
- ✅ 128: Supported
- ✅ 129 - 131: Supported
Edge
- ◐ 12 - 18: Partial support
- ✅ 79 - 127: Supported
- ✅ 128: Supported
Safari
- ❌ 3.1 - 8: Not supported
- ◐ 9 - 10.1: Partial support
- ✅ 11 - 17.5: Supported
- ✅ 17.6: Supported
- ✅ 18.0 - TP: Supported
Firefox
- ❌ 2 - 38: Not supported
- ◐ 39 - 67: Partial support
- ✅ 68 - 129: Supported
- ✅ 130: Supported
- ✅ 131 - 133: Supported
Opera
- ❌ 9 - 53: Not supported
- ❌ 54 - 63: Disabled by default
- ✅ 64 - 110: Supported
- ✅ 111: Supported
IE
- ❌ 5.5 - 9: Not supported
- ◐ 10: Partial support
- ◐ 11: Partial support
Chrome for Android
- ✅ 128: Supported
Safari on iOS
- ❌ 3.2 - 8.4: Not supported
- ◐ 9 - 10.3: Partial support
- ✅ 11 - 17.5: Supported
- ✅ 17.6: Supported
- ✅ 18.0: Supported
Samsung Internet
- ❌ 4 - 9.2: Not supported
- ✅ 10.1 - 24: Supported
- ✅ 25: Supported
Opera Mini
- ❌ all: Not supported
Opera Mobile
- ❌ 10 - 12.1: Not supported
- ✅ 80: Supported
UC Browser for Android
- ✅ 15.5: Supported
Android Browser
- ❌ 2.1 - 4.4.4: Not supported
- ✅ 128: Supported
Firefox for Android
- ✅ 127: Supported
QQ Browser
- ✅ 14.9: Supported
Baidu Browser
- ✅ 13.52: Supported
KaiOS Browser
- ◐ 2.5: Partial support
- ✅ 3: Supported
Works in the iOS WKWebView, but not UIWebView.
- Resources:
- MDN Web Docs - CSS Scroll Snap
- MDN Web Docs - CSS Scroll snap points
- Blog post
- Polyfill - based on an [older version](https://www.w3.org/TR/2015/WD-css-snappoints-1-20150326/) of the spec
- A CSS Snap Points based carousel (and lightweight polyfill)
- Polyfill - based on the [current version](https://www.w3.org/TR/css-scroll-snap-1/) of the spec