ion-fab
Fabs are container elements that contain one or more fab buttons. They should be placed in a fixed position that does not scroll with the content. Fabs should have one main fab button. Fabs can also contain one or more fab lists which contain related buttons that show when the main fab button is clicked.
Basic Usage
<ion-fab>
<ion-fab-button>
<ion-icon name="add"></ion-icon>
</ion-fab-button>
</ion-fab>
List Side
The side
property of the fab list component controls where it appears relative to the main fab button. A single fab can have multiple fab lists as long as they all have different values for side
.
<ion-fab slot="fixed" horizontal="center" vertical="center">
<ion-fab-button>
<ion-icon name="add"></ion-icon>
</ion-fab-button>
<ion-fab-list side="top">
<ion-fab-button>
<ion-icon name="chevron-up"></ion-icon>
</ion-fab-button>
</ion-fab-list>
<ion-fab-list side="end">
<ion-fab-button>
<ion-icon name="chevron-forward"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="chevron-forward"></ion-icon>
</ion-fab-button>
</ion-fab-list>
<ion-fab-list side="bottom">
<ion-fab-button>
<ion-icon name="chevron-down"></ion-icon>
</ion-fab-button>
</ion-fab-list>
<ion-fab-list side="start">
<ion-fab-button>
<ion-icon name="chevron-back"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="chevron-back"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
Positioning
In order to place the fab in a fixed position, it should be assigned to the fixed
slot of the outer content component. Use the vertical
and horizontal
props to control the alignment of the fab in the viewport. The edge
prop will cause the fab button to overlap with the app's header or footer.
<ion-header>
<ion-toolbar>
<ion-title>Fab Buttons</ion-title>
</ion-toolbar>
</ion-header>
<ion-content class="ion-padding">
<ion-fab slot="fixed" vertical="top" horizontal="start">
<ion-fab-button>
<ion-icon name="chevron-forward-circle"></ion-icon>
</ion-fab-button>
<ion-fab-list side="end">
<ion-fab-button>
<ion-icon name="document"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="color-palette"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="globe"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
<ion-fab slot="fixed" vertical="top" horizontal="end" [edge]="true">
<ion-fab-button>
<ion-icon name="chevron-down-circle"></ion-icon>
</ion-fab-button>
<ion-fab-list side="bottom">
<ion-fab-button>
<ion-icon name="document"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="color-palette"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="globe"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
<ion-fab slot="fixed" vertical="bottom" horizontal="end">
<ion-fab-button>
<ion-icon name="chevron-up-circle"></ion-icon>
</ion-fab-button>
<ion-fab-list side="top">
<ion-fab-button>
<ion-icon name="document"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="color-palette"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="globe"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
</ion-content>
Button Sizing
Setting the size
property of the main fab button to "small"
will render it at a mini size. Note that this property will not have an effect when used with the inner fab buttons.
<ion-fab>
<ion-fab-button size="small">
<ion-icon name="add"></ion-icon>
</ion-fab-button>
<ion-fab-list side="end">
<ion-fab-button>
<ion-icon name="document"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="color-palette"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="globe"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
Theming
Colors
<ion-fab slot="fixed" horizontal="center" vertical="center">
<ion-fab-button color="secondary">
<ion-icon name="add"></ion-icon>
</ion-fab-button>
<ion-fab-list side="top">
<ion-fab-button color="primary">
<ion-icon name="chevron-up"></ion-icon>
</ion-fab-button>
</ion-fab-list>
<ion-fab-list side="end">
<ion-fab-button color="tertiary">
<ion-icon name="chevron-forward"></ion-icon>
</ion-fab-button>
<ion-fab-button color="success">
<ion-icon name="chevron-forward"></ion-icon>
</ion-fab-button>
</ion-fab-list>
<ion-fab-list side="bottom">
<ion-fab-button color="warning">
<ion-icon name="chevron-down"></ion-icon>
</ion-fab-button>
</ion-fab-list>
<ion-fab-list side="start">
<ion-fab-button color="danger">
<ion-icon name="chevron-back"></ion-icon>
</ion-fab-button>
<ion-fab-button color="dark">
<ion-icon name="chevron-back"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
CSS Custom Properties
- src/app/example.component.html
- src/app/example.component.css
<ion-fab>
<ion-fab-button>
<ion-icon name="add"></ion-icon>
</ion-fab-button>
<ion-fab-list side="end">
<ion-fab-button>
<ion-icon name="document"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="color-palette"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="globe"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
CSS Shadow Parts
- src/app/example.component.html
- src/app/example.component.css
<ion-fab>
<ion-fab-button>
<ion-icon name="add"></ion-icon>
</ion-fab-button>
<ion-fab-list side="end">
<ion-fab-button>
<ion-icon name="document"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="color-palette"></ion-icon>
</ion-fab-button>
<ion-fab-button>
<ion-icon name="globe"></ion-icon>
</ion-fab-button>
</ion-fab-list>
</ion-fab>
Accessibility
Labels
Since FABs are allowed to contain only icons, developers must provide an aria-label
on each ion-fab-button
instance. Without this label, assistive technologies will not be able to announce the purpose of each button.
Properties
activated
Description | If true , both the ion-fab-button and all ion-fab-list inside ion-fab will become active. That means ion-fab-button will become a close icon and ion-fab-list will become visible. |
Attribute | activated |
Type | boolean |
Default | false |
edge
Description | If true , the fab will display on the edge of the header if vertical is "top" , and on the edge of the footer if it is "bottom" . Should be used with a fixed slot. |
Attribute | edge |
Type | boolean |
Default | false |
horizontal
Description | Where to align the fab horizontally in the viewport. |
Attribute | horizontal |
Type | "center" ๏ฝ "end" ๏ฝ "start" ๏ฝ undefined |
Default | undefined |
vertical
Description | Where to align the fab vertically in the viewport. |
Attribute | vertical |
Type | "bottom" ๏ฝ "center" ๏ฝ "top" ๏ฝ undefined |
Default | undefined |
Events
No events available for this component.
Methods
close
Description | Close an active FAB list container. |
Signature | close() => Promise<void> |
CSS Shadow Parts
No CSS shadow parts available for this component.
CSS Custom Properties
No CSS custom properties available for this component.
Slots
No slots available for this component.