Password Field
- Usage
- Styling
Password Field is an input field for entering passwords. The input is masked by default. On mobile devices, though, the last typed letter is shown for a brief moment. The masking can be toggled using an optional reveal button.
new tab
<vaadin-password-field label="Password" value="Ex@mplePassw0rd"></vaadin-password-field>
Reveal Button
The reveal button allows the user to disable masking and see the value they entered. This is especially helpful on mobile devices, where typing is more error-prone. In cases where this feature isn’t desired, it can be disabled.
new tab
<vaadin-password-field
label="Password"
value="Ex@mplePassw0rd"
reveal-button-hidden
></vaadin-password-field>
Basic Features
The following features, common to most input field components, are supported:
Label
The label is used to identify the input field. It supports plain-text content, and its length is limited to the width of the field. Helpers and Tooltips can be used to provide additional information that doesn’t fit into the label.
Visible labels are strongly recommended for all input fields. In cases where the built-in label cannot be used, an external element can be associated as the field’s label through the aria-labelledby
attribute. Fields without any visible label should include an invisible label for assistive technologies with the aria-label
attribute.
Helper
Helpers are used to provide additional information that the user may need to enter in the field, such as format requirements or explanations of the field’s purpose below the field.
A style variant is available for rendering the helper above the field.
In addition to plain text, helpers can contain components and HTML elements. However, complex and interactive content is likely to have accessibility issues.
Placeholder
The placeholder is text that’s displayed when the field is empty. Its primary purpose is to provide a short input hint (e.g., the expected format) in situations where a Helper cannot be used.
Placeholders should not be used as a replacement for a visible label. They can be mistaken for a manually entered value. See Label for alternatives to the built-in field label.
Tooltip
Tooltips are small text pop-ups displayed on hover, and on keyboard-focus. They can be used to provide additional information about a field. This can be useful in situations where an always visible Helper is not appropriate. Helpers are generally recommended in favor of tooltips, though, as they provide much better discoverability and mobile support. See the Tooltip documentation for more information.
Prefix & Suffix
Prefix and suffix elements — rendered at either end of the field — can be used to display units, icons, and similar visual cues to the field’s purpose or format.
External & Invisible Labels (ARIA)
Visible labels are strongly recommended for all input fields. In situations where the built-in label cannot be used, an external element can be associated as the field’s label through its element id
. Fields without any visible label should be provided an invisible label for assistive technologies like screen readers.
<!-- Associates external element as label: -->
<label id="external-label">This is the label</label>
<vaadin-password-field accessible-name-ref="external-label">...
<!-- Invisible label for screen readers: -->
<vaadin-password-field accessible-name="This is the label">...
new tab
<vaadin-password-field
label="Label"
helper-text="Helper text"
placeholder="Placeholder"
clear-button-visible
>
<vaadin-tooltip slot="tooltip" text="Tooltip text"></vaadin-tooltip>
<vaadin-icon slot="prefix" icon="vaadin:lock"></vaadin-icon>
</vaadin-password-field>
Validation
Password Field provides a validation mechanism based on constraints. Constraints allow you to define criteria that the value must meet to be considered valid. Validation occurs typically when the user initiates a value change, for example by entering input and pressing Enter. If the value is invalid, the field is highlighted in red, and an error message appears underneath the input. Certain constraints, however, can proactively prevent users from entering characters that would result in an invalid value.
Below is a list of supported constraints with more detailed information:
Required
Required fields are marked with an indicator next to the label, and become invalid if their value is first entered and then cleared.
An instruction text at the top of the form explaining the required indicator is recommended. The indicator itself can be customized with the --lumo-required-field-indicator
style property.
Min & Max Length
The minimum and maximum input length value constraints dictate the smallest, and the largest number of characters a field accepts. It triggers a validation error if a value shorter than the minimum length is entered, and limits text entered to the maximum length. They can be used to enforce specific formats, or to cap the value to the length supported by the underlying database schema.
In cases where the length requirements may not be clear to the user, it’s recommended to provide this information, for example by using a Helper.
Allowed Characters
A separate single-character, regular expression can be used to restrict the characters that can be entered into the field. Characters that don’t match the expression are rejected. However, values set programmatically are not subject to this restriction, even if they contain disallowed characters.
new tab
<vaadin-password-field
pattern="^[A-Za-z0-9]+$"
required
minlength="6"
maxlength="12"
label="Password"
helper-text="6 to 12 characters. Only letters A-Z and numbers supported."
.errorMessage="${this.errorMessage}"
@validated="${(event: PasswordFieldValidatedEvent) => {
const field = event.target as PasswordField;
const { validity } = field.inputElement as HTMLInputElement;
if (validity.valueMissing) {
this.errorMessage = 'Field is required';
} else if (validity.tooShort) {
this.errorMessage = `Minimum length is ${field.minlength} characters`;
} else if (validity.tooLong) {
this.errorMessage = `Maximum length is ${field.maxlength} characters`;
} else if (validity.patternMismatch) {
this.errorMessage = 'Only letters A-Z and numbers are allowed';
} else {
this.errorMessage = '';
}
}}"
></vaadin-password-field>
It’s important to ensure an appropriate error message is configured for each constraint violation to provide users with clear feedback.
Read-Only & Disabled
Fields used to display values should be set to read-only
mode to prevent editing. Read-only fields are focusable and visible to screen readers. They can display tooltips. Their values can be selected and copied.
Fields that are currently unavailable should be disabled
. The reduced contrast of disabled fields makes them inappropriate for displaying information. They can’t be focused or display tooltips. They’re invisible to screen readers, and their values cannot be selected and copied.
Disabled fields can be useful in situations where they can become enabled based on some user action. Consider hiding fields entirely if there’s nothing the user can do to make them editable.
new tab
<vaadin-password-field readonly label="Read-only" value="Ex@mplePassw0rd">
</vaadin-password-field>
<vaadin-password-field disabled label="Disabled"></vaadin-password-field>
Style Variants
The following style variants can be applied:
Text Alignment
Three different text alignments are supported: left
, which is the default; center
; and right
.
Right-alignment is recommended for numerical values when presented in vertical groups. This tends to aid interpretation and comparison of values.
Small Variant
The small variant can be used to make individual fields more compact. The default size of fields can be customized with style properties.
Helper Above Field
The helper can be rendered above the field, and below the label.
Borders
Borders can be applied to the field surface by providing a value (e.g., 1px
) to the --vaadin-input-field-border-width
CSS property. This can be applied globally to all input fields using the html
selector, or to individual component instances. Borders are required to achieve WCAG 2.1 level AA conformant color contrast with the default Lumo styling of fields.
You can override the default border color with the --vaadin-input-field-border-color
property.
new tab
<vaadin-password-field
theme="align-right small helper-above-field"
label="Label"
helper-text="Helper text"
value="Ex@mplePassw0rd"
style="--vaadin-input-field-border-width: 1px;"
></vaadin-password-field>
Best Practices
Express clearly your password requirements to the user, so that they don’t have to guess. The Helper feature is appropriate for this purpose.
new tab
<vaadin-password-field
label="Password"
helper-text="A password must be at least 8 characters.
It has to have at least one letter and one digit."
pattern="^(?=.*[0-9])(?=.*[a-zA-Z]).{8}.*$"
error-message="Not a valid password"
></vaadin-password-field>
Showing the strength of the entered password can also be a motivating factor for users to create better passwords. You could display it with a more advanced Helper:
new tab
<vaadin-password-field
label="Password"
@value-changed="${this.onPasswordChanged}"
pattern="${this.pattern}"
error-message="Not a valid password"
>
<vaadin-icon
icon="vaadin:check"
slot="suffix"
style="color:${StrengthColor.strong}"
?hidden="${this.strengthText !== 'strong'}"
></vaadin-icon>
<div slot="helper">
Password strength:
<span style="color:${this.strengthColor}">${this.strengthText}</span>
</div>
</vaadin-password-field>
F578D95F-02B0-43C1-96CD-26926B472701