dataset & data-* attributes

- LS

Method of applying and accessing custom data to elements.

Chrome

  1. 4 - 6: Partial support
  2. 7 - 44: Supported
  3. 45 - 54: Supported
  4. 55 - 122: Supported
  5. 123: Supported
  6. 124 - 126: Supported

Edge

  1. 12 - 16: Supported
  2. 17 - 122: Supported
  3. 123: Supported

Safari

  1. 3.1 - 5: Partial support
  2. 5.1 - 17.3: Supported
  3. 17.4: Supported
  4. TP: Supported

Firefox

  1. 2 - 5: Partial support
  2. 6 - 50: Supported
  3. 51 - 123: Supported
  4. 124: Supported
  5. 125 - 127: Supported

Opera

  1. 9 - 11: Partial support
  2. 11.1 - 12.1: Supported
  3. 15 - 31: Supported
  4. 32 - 41: Supported
  5. 42 - 107: Supported
  6. 108: Supported

IE

  1. 5.5 - 10: Partial support
  2. 11: Supported

Chrome for Android

  1. 122: Supported

Safari on iOS

  1. 3.2 - 4.3: Partial support
  2. 5 - 17.3: Supported
  3. 17.4: Supported

Samsung Internet

  1. 4 - 22: Supported
  2. 23: Supported

Opera Mini

  1. all: Partial support

Opera Mobile

  1. 10 - 11: Partial support
  2. 11.1 - 12.1: Supported
  3. 80: Supported

UC Browser for Android

  1. 15.5: Supported

Android Browser

  1. 2.1 - 2.3: Partial support
  2. 3 - 4.4.4: Supported
  3. 122: Supported

Firefox for Android

  1. 123: Supported

QQ Browser

  1. 14.9: Supported

Baidu Browser

  1. 13.52: Supported

KaiOS Browser

  1. 2.5: Supported
  2. 3: Supported

Partial support refers to being able to use data-* attributes and access them using getAttribute.

"Supported" refers to accessing the values using the dataset property. Current spec only refers to support on HTML elements, only some browsers also have support for SVG/MathML elements.

Resources:
MDN Web Docs - dataset
MDN Guide - Using data-* attributes
Demo using dataset
HTML5 Doctor article
has.js test
WebPlatform Docs