CSS Scroll Snap

- CR

CSS technique that allows customizable scrolling experiences like pagination of carousels by setting defined snap positions.

Chrome

  1. 4 - 65: Not supported
  2. 66 - 68: Disabled by default
  3. 69 - 118: Supported
  4. 119: Supported
  5. 120 - 122: Supported

Edge

  1. 12 - 18: Partial support
  2. 79 - 118: Supported
  3. 119: Supported

Safari

  1. 3.1 - 8: Not supported
  2. 9 - 10.1: Partial support
  3. 11 - 17.0: Supported
  4. 17.1: Supported
  5. 17.2 - TP: Supported

Firefox

  1. 2 - 38: Not supported
  2. 39 - 67: Partial support
  3. 68 - 119: Supported
  4. 120: Supported
  5. 121 - 123: Supported

Opera

  1. 9 - 53: Not supported
  2. 54 - 63: Disabled by default
  3. 64 - 103: Supported
  4. 104: Supported

IE

  1. 5.5 - 9: Not supported
  2. 10: Partial support
  3. 11: Partial support

Chrome for Android

  1. 119: Supported

Safari on iOS

  1. 3.2 - 8.4: Not supported
  2. 9 - 10.3: Partial support
  3. 11 - 17.0: Supported
  4. 17.1: Supported
  5. 17.2: Supported

Samsung Internet

  1. 4 - 9.2: Not supported
  2. 10.1 - 22: Supported
  3. 23: Supported

Opera Mini

  1. all: Not supported

Opera Mobile

  1. 10 - 12.1: Not supported
  2. 73: Supported

UC Browser for Android

  1. 15.5: Supported

Android Browser

  1. 2.1 - 4.4.4: Not supported
  2. 119: Supported

Firefox for Android

  1. 119: Supported

QQ Browser

  1. 13.1: Supported

Baidu Browser

  1. 13.18: Supported

KaiOS Browser

  1. 2.5: Partial support
  2. 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