Alert
Puoi fornire dei feedback all’utente tramite messaggi di avviso.
Esempi
Gli avvisi sono disponibili in quattro tipologie diverse e sono adatti a qualsiasi lunghezza di testo. Inoltre possono prevedere un pulsante di chiusura utilizzando un pulsante con attributo data-bs-dismiss="alert"
.
Questo è un alert di tipo "primary".
Questo è un alert di tipo "info".
Questo è un alert di tipo "success".
Questo è un alert di tipo "warning".
Questo è un alert di tipo "danger".
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<div class="alert alert-primary" role="alert">
<p class="mb-0"><svg class="alert-icon icon"><use href="/dist/svg/sprites.svg#it-info-circle"></use></svg> Questo è un alert di tipo "<strong>primary</strong>".</p>
</div>
<div class="alert alert-info" role="alert">
<p class="mb-0"><svg class="alert-icon icon"><use href="/dist/svg/sprites.svg#it-info-circle"></use></svg> Questo è un alert di tipo "<strong>info</strong>".</p>
</div>
<div class="alert alert-success" role="alert">
<p class="mb-0"><svg class="alert-icon icon"><use href="/dist/svg/sprites.svg#it-check-circle"></use></svg> Questo è un alert di tipo "<strong>success</strong>".</p>
</div>
<div class="alert alert-warning" role="alert">
<p class="mb-0"><svg class="alert-icon icon"><use href="/dist/svg/sprites.svg#it-warning-circle"></use></svg> Questo è un alert di tipo "<strong>warning</strong>".</p>
</div>
<div class="alert alert-danger" role="alert">
<p class="mb-0"><svg class="alert-icon icon"><use href="/dist/svg/sprites.svg#it-error"></use></svg> Questo è un alert di tipo "<strong>danger</strong>".</p>
</div>
Trasmettere significato alle tecnologie assistive
L’uso del colore per aggiungere un significato fornisce solo un’indicazione visiva, che non sarà trasmesso agli utenti di tecnologie assistive – come gli screen reader. Assicurati che le informazioni denotate dal colore siano rese disponibili anche dal contenuto stesso (es.: il testo visibile), o siano incluse attraverso mezzi alternativi, come testo aggiuntivo nascosto con la classe .visually-hidden
.
Link evidenziato
Usa la classe .alert-link
per dare risalto ad un link all’interno dell’alert.
1
2
3
<div class="alert alert-danger" role="alert">
Questo è un alert con un esempio di <a href="#" class="alert-link">link</a> evidenziato.
</div>
Contenuto aggiuntivo
I messaggi di avviso possono avere del contenuto HTML aggiuntivo come intestazioni, paragrafi e divisori.
Avviso di successo!
Stai leggendo questo importante messaggio di avviso di successo. Questo testo di esempio sarà più lungo in modo da poter vedere come funzioni la spaziatura all'interno di un avviso con questo tipo di contenuto.
Quando necessario, assicurarti di inserire le utilità di margine per mantenere gli spazi equilibrati.
1
2
3
4
5
6
<div class="alert alert-success" role="alert">
<h4 class="alert-heading">Avviso di successo!</h4>
<p>Stai leggendo questo importante messaggio di avviso di successo. Questo testo di esempio sarà più lungo in modo da poter vedere come funzioni la spaziatura all'interno di un avviso con questo tipo di contenuto.</p>
<hr>
<p class="mb-0">Quando necessario, assicurarti di inserire le utilità di margine per mantenere gli spazi equilibrati.</p>
</div>
Chiusura
È possibile eliminare qualsiasi avviso mediante un pulsante di chiusura:
- Inserisci il pulsante di chiusura e la classe
.alert-dismissible
, verrà così aggiunto un ulteriore padding alla destra dell’avviso e posizionerà correttamente il pulsante.btn-close
. - Sul pulsante di chiusura, aggiungi l’attributo
data-bs-dismiss="alert"
, che attiverà la funzionalità JavaScript. Assicurati di utilizzare l’elemento<button>
per un comportamento corretto su tutti i dispositivi. - Per animare gli avvisi quando li si elimina, assicurarsi di aggiungere le classi
.fade
e.show
.
Accessibilità
L’aria label che assegna il nome accessibile all’icona di chiusura, che nell’esempio è “chiudi avviso”, deve essere correlato al contesto.
Ad esempio “chiudi nota”, “chiudi”, “nascondi”, ecc.
Clicca sul pulsante di chiusura per vedere la funzionalità di rimozione alert in azione:
1
2
3
4
5
6
<div class="alert alert-warning alert-dismissible fade show" role="alert">
<strong>Attenzione</strong> Alcuni campi inseriti sono da controllare.
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Chiudi avviso">
<svg class="icon"><use href="/dist/svg/sprites.svg#it-close"></use></svg>
</button>
</div>
Tramite JavaScript
Abilita la chiusura di un alert tramite JavaScript:
1
2
3
4
var alertList = document.querySelectorAll('.alert')
alertList.forEach(function (alert) {
new bootstrap.Alert(alert)
})
Oppure con l’assegnazione dell’attributo data
in un pulsante all’interno dell’alert, come nell’esempio seguente:
1
2
3
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Chiudi avviso">
<span aria-hidden="true">×</span>
</button>
Nota che chiudendo un alert lo rimuoverai dal DOM.
Metodi
Metodo | Descrizione |
---|---|
close |
Chiude un alert rimuovendolo dal DOM. Se le classi .fade e .show sono presenti nell’elemento, l’avviso verrà chiuso con effetto scomparsa. |
dispose |
L’alert viene rimosso. |
getInstance |
Static method which allows you to get the alert instance associated to a DOM element, you can use it like this: bootstrap.Alert.getInstance(alert) |
getOrCreateInstance |
Static method which returns an alert instance associated to a DOM element or create a new one in case it wasn’t initialised. You can use it like this: bootstrap.Alert.getOrCreateInstance(element) |
1
2
3
var alertNode = document.querySelector('.alert')
var alert = bootstrap.Alert.getInstance(alertNode)
alert.close()
Eventi
Il plugin alert di Bootstrap mette a disposizione alcuni eventi per agganciare la funzionalità di avviso.
Evento | Descrizione |
---|---|
close.bs.alert |
Questo evento si attiva immediatamente quando viene chiamato il metodo di istanza close . |
closed.bs.alert |
Questo evento viene attivato quando l’avviso è stato chiuso (attenderà il completamento delle transizioni CSS). |
1
2
3
4
5
6
var myAlert = document.getElementById('myAlert')
myAlert.addEventListener('closed.bs.alert', function () {
// do something, for instance, explicitly move focus to the most appropriate element,
// so it doesn't get lost/reset to the start of the page
// document.getElementById('...').focus()
})