Icons describe the type of input a text field requires. They can also be interaction targets.
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">event</i>
We recommend using Material Icons from Google Fonts:
<head>
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
</head>
However, you can also use SVG, Font Awesome, or any other icon library you wish.
@import "@material/textfield/icon/mdc-text-field-icon";
import {MDCTextFieldIcon} from '@material/textfield/icon';
const icon = new MDCTextFieldIcon(document.querySelector('.mdc-text-field-icon'));
Leading and trailing icons can be applied to default or mdc-text-field--outlined
Text Fields. To add an icon, add the relevant class (mdc-text-field--with-leading-icon
and/or mdc-text-field--with-trailing-icon
) to the root element, add an i
element with your preferred icon, and give it a class of mdc-text-field__icon
. If using 2 icons at the same time, the first icon inside the mdc-text-field
element will be interpreted as the leading icon and the second icon will be interpreted as the trailing icon.
NOTE: if you would like to display un-clickable icons, simply omit
tabindex="0"
androle="button"
, and the CSS will ensure the cursor is set to default, and that interacting with an icon doesn't do anything unexpected.
In text field:
<div class="mdc-text-field mdc-text-field--with-leading-icon">
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">event</i>
<input type="text" id="my-input" class="mdc-text-field__input">
<label for="my-input" class="mdc-floating-label">Your Name</label>
<div class="mdc-line-ripple"></div>
</div>
In outlined text field:
<div class="mdc-text-field mdc-text-field--outlined mdc-text-field--with-leading-icon">
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">event</i>
<input type="text" id="my-input" class="mdc-text-field__input">
<div class="mdc-notched-outline">
<div class="mdc-notched-outline__leading"></div>
<div class="mdc-notched-outline__notch">
<label for="my-input" class="mdc-floating-label">Your Name</label>
</div>
<div class="mdc-notched-outline__trailing"></div>
</div>
</div>
In text field:
<div class="mdc-text-field mdc-text-field--with-trailing-icon">
<input type="text" id="my-input" class="mdc-text-field__input">
<label for="my-input" class="mdc-floating-label">Your Name</label>
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">event</i>
<div class="mdc-line-ripple"></div>
</div>
In outlined text field:
<div class="mdc-text-field mdc-text-field--outlined mdc-text-field--with-trailing-icon">
<input type="text" id="my-input" class="mdc-text-field__input">
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">event</i>
<div class="mdc-notched-outline">
<div class="mdc-notched-outline__leading"></div>
<div class="mdc-notched-outline__notch">
<label for="my-input" class="mdc-floating-label">Your Name</label>
</div>
<div class="mdc-notched-outline__trailing"></div>
</div>
</div>
In text field:
<div class="mdc-text-field mdc-text-field--with-leading-icon mdc-text-field--with-trailing-icon">
<i class="material-icons mdc-text-field__icon">phone</i>
<input type="text" id="my-input" class="mdc-text-field__input">
<label for="my-input" class="mdc-floating-label">Phone Number</label>
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">event</i>
<div class="mdc-line-ripple"></div>
</div>
In outlined text field:
<div class="mdc-text-field mdc-text-field--outlined mdc-text-field--with-leading-icon mdc-text-field--with-trailing-icon">
<i class="material-icons mdc-text-field__icon">phone</i>
<input type="text" id="my-input" class="mdc-text-field__input">
<i class="material-icons mdc-text-field__icon" tabindex="0" role="button">clear</i>
<div class="mdc-notched-outline">
<div class="mdc-notched-outline__leading"></div>
<div class="mdc-notched-outline__notch">
<label for="my-input" class="mdc-floating-label">Phone Number</label>
</div>
<div class="mdc-notched-outline__trailing"></div>
</div>
</div>
CSS Class | Description |
---|---|
mdc-text-field-icon |
Mandatory. |
Mixin | Description |
---|---|
mdc-text-field-icon-color($color, $styleSecondIcon: false) |
Customizes the color for the leading/trailing icons. If the $styleSecondIcon is true it will output the color to only apply to a trailing icon when used with a leading icon. |
Property | Value Type | Description |
---|---|---|
foundation |
MDCTextFieldIconFoundation |
Returns the icon's foundation. This allows the parent MDCTextField component to access the public methods on the MDCTextFieldIconFoundation class. |
If you are using a JavaScript framework, such as React or Angular, you can create a Text Field Icon for your framework. Depending on your needs, you can use the Simple Approach: Wrapping MDC Web Vanilla Components, or the Advanced Approach: Using Foundations and Adapters. Please follow the instructions here.
Method Signature | Description |
---|---|
getAttr(attr: string) => string |
Gets the value of an attribute on the icon element. |
setAttr(attr: string, value: string) => void |
Sets an attribute with a given value on the icon element. |
removeAttr(attr: string) => void |
Removes an attribute from the icon element. |
setContent(content: string) => void |
Sets the text content of the icon element. |
registerInteractionHandler(evtType: string, handler: EventListener) => void |
Registers an event listener for a given event. |
deregisterInteractionHandler(evtType: string, handler: EventListener) => void |
Deregisters an event listener for a given event. |
notifyIconAction() => void |
Emits a custom event "MDCTextField:icon" denoting a user has clicked the icon, which bubbles to the top-level text field element. |
Method Signature | Description |
---|---|
setDisabled(disabled: boolean) => void |
Updates the icon's disabled state. |
setAriaLabel(label: string) => void |
Updates the icon's aria-label. |
setContent(content: string) => void |
Updates the icon's text content. |
handleInteraction(evt: Event) => void |
Handles a text field interaction event. |