Video element

- LS

Method of playing videos on webpages (without requiring a plug-in). Includes support for the following media properties: currentSrc, currentTime, paused, playbackRate, buffered, duration, played, seekable, ended, autoplay, loop, controls, volume & muted

Chrome

  1. 4 - 118: Supported
  2. 119: Supported
  3. 120 - 122: Supported

Edge

  1. 12 - 118: Supported
  2. 119: Supported

Safari

  1. 3.1 - 3.2: Not supported
  2. 4 - 10.1: Supported
  3. 11 - 17.0: Supported
  4. 17.1: Supported
  5. 17.2 - TP: Supported

Firefox

  1. 2 - 3: Not supported
  2. 3.5 - 19: Partial support
  3. 20 - 119: Supported
  4. 120: Supported
  5. 121 - 123: Supported

Opera

  1. 9 - 10.1: Not supported
  2. 10.5 - 103: Supported
  3. 104: Supported

IE

  1. 5.5 - 8: Not supported
  2. 9 - 10: Supported
  3. 11: Supported

Chrome for Android

  1. 119: Supported

Safari on iOS

  1. 3.2 - 10.3: Supported
  2. 11 - 17.0: Supported
  3. 17.1: Supported
  4. 17.2: Supported

Samsung Internet

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

Opera Mini

  1. all: Not supported

Opera Mobile

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

UC Browser for Android

  1. 15.5: Supported

Android Browser

  1. 2.1 - 2.2: Partial support
  2. 2.3 - 4.4.4: Supported
  3. 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: Supported
  2. 3: Supported

Different browsers have support for different video formats, see sub-features for details.

Resources:
Video for Everybody
Video on the Web - includes info on Android support
Detailed article on video/audio elements
has.js test
WebPlatform Docs
WebM format information
Sub-features:
WebM video format
MPEG-4/H.264 video format
Ogg/Theora video format
WebVTT - Web Video Text Tracks
HEVC/H.265 video format
AV1 video format