:user-valid
Baseline 2023Newly available
Since November 2023, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
The :user-valid
CSS pseudo-class represents any validated form element whose value validates correctly based on its validation constraints. However, unlike :valid
it only matches once the user has interacted with it.
This pseudo-class is applied if the form control is valid and any of the following has occurred:
- The user made a change to the form control and committed the change such as by moving focus elsewhere.
- The user has attempted to submit the form, even if no change was made to the control.
- The value was invalid when it gained focus, and the user made a change making it valid, even if focus is still in the control.
Once this pseudo-class has been applied, the user-agent re-validates whether the control is valid at every keystroke when the control has focus.
- If the control has focus, and the value was invalid when it gained focus, re-validate on every keystroke.
The result is that if the control was valid when the user started interacting with it, the validity styling is changed only when the user shifts focus to another control. However, if the user is trying to correct a previously-flagged value, the control shows immediately when the value becomes valid. Required items are flagged as invalid only if the user changes them or attempts to submit an unchanged invalid value.
Syntax
:user-valid {
/* ... */
}
Examples
Setting a color and symbol on :user-valid
In the following example, the green border and ✅ only display once the user has interacted with the field. Try changing the email address to another valid email to see it in action.
<form>
<label for="email">Email *: </label>
<input
id="email"
name="email"
type="email"
value="test@example.com"
required />
<span></span>
</form>
input:user-valid {
border: 2px solid green;
}
input:user-valid + span::before {
content: "✓";
color: green;
}
Specifications
Specification |
---|
HTML Standard # selector-user-valid |
Selectors Level 4 # user-valid-pseudo |
Browser compatibility
Report problems with this compatibility data on GitHubdesktop | mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
:user-valid |
Legend
Tip: you can click/tap on a cell for more information.
- Full support
- Full support
- No support
- No support
- Uses a non-standard name.
- Has more compatibility info.