Form validation

- LS

Method of setting required fields and field types without requiring JavaScript. This includes preventing forms from being submitted when appropriate, the checkValidity() method as well as support for the :invalid, :valid, and :required CSS pseudo-classes.

IE

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

Edge

  1. 12 - 85: Supported
  2. 86: Supported

Firefox

  1. 2 - 3.6: Not supported
  2. 4 - 80: Supported
  3. 81: Supported
  4. 82 - 83: Supported

Chrome

  1. 4 - 9: Not supported
  2. 10 - 85: Supported
  3. 86: Supported
  4. 87 - 89: Supported

Safari

  1. 3.1 - 4: Not supported
  2. 5 - 10: Partial support
  3. 10.1 - 13.1: Supported
  4. 14: Supported
  5. TP: Supported

Opera

  1. 9 - 9.6: Not supported
  2. 10 - 70: Supported
  3. 71: Supported

iOS Safari

  1. 3.2: Not supported
  2. 4 - 10.2: Partial support
  3. 10.3 - 13.7: Supported
  4. 14: Supported

Opera Mini

  1. all: Partial support

Android Browser

  1. 2.1 - 3: Not supported
  2. 4 - 4.4: Partial support
  3. 4.4.3: Supported
  4. 81: Supported

Blackberry Browser

  1. 7: Partial support
  2. 10: Supported

Opera Mobile

  1. 10 - 12.1: Supported
  2. 59: Supported

Chrome for Android

  1. 85: Supported

Firefox for Android

  1. 79: Supported

IE Mobile

  1. 10: Partial support
  2. 11: Partial support

UC Browser for Android

  1. 12.12: Supported

Samsung Internet

  1. 4 - 11.2: Supported
  2. 12.0: Supported

QQ Browser

  1. 10.4: Supported

Baidu Browser

  1. 7.12: Supported

KaiOS Browser

  1. 2.5: Partial support
Resources:
WebKit Blog: HTML Interactive Form Validation
WebPlatform Docs
Sub-features:
Pattern attribute for input fields
Minimum length attribute for input fields
maxlength attribute for input and textarea elements
:optional CSS pseudo-class