:required
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die :required
CSS Pseudoklasse repräsentiert jedes <input>
, <select>
oder <textarea>
Element, das das required
-Attribut gesetzt hat.
Probieren Sie es aus
label {
display: block;
margin-top: 1em;
}
.req {
color: red;
}
*:required {
background-color: gold;
}
<form>
<label for="name">Name: <span class="req">*</span></label>
<input id="name" name="name" type="text" required />
<label for="birth">Date of Birth:</label>
<input id="birth" name="birth" type="date" />
<label for="origin"
>How did you find out about us? <span class="req">*</span></label
>
<select id="origin" name="origin" required>
<option>Google</option>
<option>Facebook</option>
<option>Advertisement</option>
</select>
<p><span class="req">*</span> - Required field</p>
</form>
Diese Pseudoklasse ist nützlich, um Felder hervorzuheben, die gültige Daten enthalten müssen, bevor ein Formular abgeschickt werden kann.
Hinweis:
Die Pseudoklasse :optional
wählt optionale Eingabefelder aus.
Syntax
:required {
/* ... */
}
Barrierefreiheit
Pflicht-<input>
-Felder sollten das required
-Attribut haben. Dies stellt sicher, dass Personen, die mit unterstützender Technologie wie einem Screenreader navigieren, verstehen können, welche Eingaben gültige Inhalte benötigen, um eine erfolgreiche Übermittlung sicherzustellen.
Wenn das Formular auch optionale Eingaben enthält, sollten verpflichtende Eingaben visuell angezeigt werden, ohne dass die Bedeutung ausschließlich durch Farbe vermittelt wird. Typischerweise wird erklärender Text und/oder ein Symbol verwendet.
Beispiele
Das Pflichtfeld hat einen roten Rahmen
HTML
<form>
<div class="field">
<label for="url_input">Enter a URL:</label>
<input type="url" id="url_input" />
</div>
<div class="field">
<label for="email_input">Enter an email address:</label>
<input type="email" id="email_input" required />
</div>
</form>
CSS
label {
display: block;
margin: 1px;
padding: 1px;
}
.field {
margin: 1px;
padding: 1px;
}
input:required {
border-color: #800000;
border-width: 3px;
}
input:required:invalid {
border-color: #c00000;
}
Ergebnis
Spezifikationen
Specification |
---|
HTML # selector-required |
Selectors Level 4 # required-pseudo |
Browser-Kompatibilität
BCD tables only load in the browser
Siehe auch
- Andere Pseudoklassen, die sich auf Validierung beziehen:
:optional
,:invalid
,:valid
- Formulardatenvalidierung