Autocompletamento
Elementi e stili per la creazione di input con autocompletamento.
Esempio di autocompletamento
Il completamento automatico è un componente che aiuta gli utenti a scegliere le risposte da un elenco fornito.
Per la creazione del componente, è stato utilizzato il plugin Accessible autocomplete.
Per una corretta implementazione si consiglia di consultare la documentazione.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<div class="select-wrapper">
<label for="accessibleAutocomplete">Provincia</label>
<select class="form-control" id="accessibleAutocomplete" title="Scegli una provincia" required>
<option selected value="">Scegli una opzione</option>
<option value='AG'>Agrigento</option>
<option value='AL'>Alessandria</option>
<option value='AN'>Ancona</option>
<option value='AO'>Aosta</option>
<option value='AR'>Arezzo</option>
<option value='AP'>Ascoli Piceno</option>
<option value='AT'>Asti</option>
<option value='AV'>Avellino</option>
<option value='BA'>Bari</option>
<option value='BT'>Barletta-Andria-Trani</option>
<option value='BL'>Belluno</option>
<option value='BN'>Benevento</option>
<option value='BG'>Bergamo</option>
<option value='BI'>Biella</option>
<option value='BO'>Bologna</option>
<option value='BZ'>Bolzano</option>
<option value='BS'>Brescia</option>
<option value='BR'>Brindisi</option>
<option value='CA'>Cagliari</option>
<option value='CL'>Caltanissetta</option>
<option value='CB'>Campobasso</option>
<option value='CI'>Carbonia-Iglesias</option>
<option value='CE'>Caserta</option>
<option value='CT'>Catania</option>
<option value='CZ'>Catanzaro</option>
<option value='CH'>Chieti</option>
<option value='CO'>Como</option>
<option value='CS'>Cosenza</option>
<option value='CR'>Cremona</option>
<option value='KR'>Crotone</option>
<option value='CN'>Cuneo</option>
<option value='EN'>Enna</option>
<option value='FM'>Fermo</option>
<option value='FE'>Ferrara</option>
<option value='FI'>Firenze</option>
<option value='FG'>Foggia</option>
<option value='FC'>Forlì-Cesena</option>
<option value='FR'>Frosinone</option>
<option value='GE'>Genova</option>
<option value='GO'>Gorizia</option>
<option value='GR'>Grosseto</option>
<option value='IM'>Imperia</option>
<option value='IS'>Isernia</option>
<option value='SP'>La Spezia</option>
<option value='AQ'>L\'Aquila</option>
<option value='LT'>Latina</option>
<option value='LE'>Lecce</option>
<option value='LC'>Lecco</option>
<option value='LI'>Livorno</option>
<option value='LO'>Lodi</option>
<option value='LU'>Lucca</option>
<option value='MC'>Macerata</option>
<option value='MN'>Mantova</option>
<option value='MS'>Massa-Carrara</option>
<option value='MT'>Matera</option>
<option value='ME'>Messina</option>
<option value='MI'>Milano</option>
<option value='MO'>Modena</option>
<option value='MB'>Monza e della Brianza</option>
<option value='NA'>Napoli</option>
<option value='NO'>Novara</option>
<option value='NU'>Nuoro</option>
<option value='OT'>Olbia-Tempio</option>
<option value='OR'>Oristano</option>
<option value='PD'>Padova</option>
<option value='PA'>Palermo</option>
<option value='PR'>Parma</option>
<option value='PV'>Pavia</option>
<option value='PG'>Perugia</option>
<option value='PU'>Pesaro e Urbino</option>
<option value='PE'>Pescara</option>
<option value='PC'>Piacenza</option>
<option value='PI'>Pisa</option>
<option value='PT'>Pistoia</option>
<option value='PN'>Pordenone</option>
<option value='PZ'>Potenza</option>
<option value='PO'>Prato</option>
<option value='RG'>Ragusa</option>
<option value='RA'>Ravenna</option>
<option value='RC'>Reggio Calabria</option>
<option value='RE'>Reggio Emilia</option>
<option value='RI'>Rieti</option>
<option value='RN'>Rimini</option>
<option value='RM'>Roma</option>
<option value='RO'>Rovigo</option>
<option value='SA'>Salerno</option>
<option value='VS'>Medio Campidano</option>
<option value='SS'>Sassari</option>
<option value='SV'>Savona</option>
<option value='SI'>Siena</option>
<option value='SR'>Siracusa</option>
<option value='SO'>Sondrio</option>
<option value='TA'>Taranto</option>
<option value='TE'>Teramo</option>
<option value='TR'>Terni</option>
<option value='TO'>Torino</option>
<option value='OG'>Ogliastra</option>
<option value='TP'>Trapani</option>
<option value='TN'>Trento</option>
<option value='TV'>Treviso</option>
<option value='TS'>Trieste</option>
<option value='UD'>Udine</option>
<option value='VA'>Varese</option>
<option value='VE'>Venezia</option>
<option value='VB'>Verbano-Cusio-Ossola</option>
<option value='VC'>Vercelli</option>
<option value='VR'>Verona</option>
<option value='VV'>Vibo Valentia</option>
<option value='VI'>Vicenza</option>
<option value='VT'>Viterbo</option>
</select>
</div>
<script>
document.addEventListener('DOMContentLoaded', function () {
var selectElement = document.querySelector('#accessibleAutocomplete');
var selectAutocomplete = new bootstrap.SelectAutocomplete(selectElement, {
showAllValues: true,
defaultValue: '',
autoselect: false,
showNoOptionsFound: false,
dropdownArrow: () => '',
});
})
</script>
Per ottenere il valore della option che siamo andati a selezionare occorre agire su _element
dell’oggetto SelectAutocomplete
1
2
const e = selectAutocomplete._element;
const value = e.options[e.selectedIndex].value;
Cambiare i valori dinamicamente
In questo esempio viene mostrato come popolare il componente con dati che
cambiano a fronte di un altro input, ad esempio il valore di un altro elemento
di un form (come una select nell’esempio che segue).
Per far fronte a questa esigenza è sufficiente passare al parametro source
del costruttore una funzione per filtrare i dati e popolare il componente.
Per maggiori informazioni si rimanda alla documentazione ufficiale.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<div class="row">
<div class="col-12 mt-5">
<div class="select-wrapper">
<label for="category">Categoria alimento</label>
<select id="category" name="category">
<option value="frutta" selected>Frutta</option>
<option value="verdura">Verdura</option>
</select>
</div>
</div>
<div class="col-12 mt-5">
<div class="select-wrapper">
<label for="productAutocomplete">Alimento</label>
<select class="form-control" id="productAutocomplete" title="Scegli un prodotto">
</select>
</div>
</div>
<script>
const form_data = {
'frutta' : [
'Mela',
'Pera',
'Melone',
'Banana',
],
'verdura' : [
'Carota',
'Zucchina',
'Melanzana',
'Carciofo',
],
}
document.addEventListener('DOMContentLoaded', function () {
const categorySelect = document.getElementById("category");
const selectElement = document.getElementById("productAutocomplete");
const selectAutocomplete = new bootstrap.SelectAutocomplete(selectElement, {
required: true,
name: 'productAutocomplete',
confirmOnBlur: false,
showAllValues: true,
defaultValue: '',
autoselect: false,
showNoOptionsFound: false,
dropdownArrow: () => '',
source: (query, populateResults) => {
const results = form_data[categorySelect.value]
const filteredResults = results.filter(result => result.indexOf(query) !== -1)
populateResults(filteredResults)
}
});
// Facoltativo: se si vuole cancellare l'elemento al cambio del filtro
categorySelect.addEventListener('change', (event) => {
document.getElementById("productAutocomplete").value = '';
});
})
</script>
</div>
Validazione
Per la validazione del campo con autocompletamento, si consiglia di utilizzare il plugin Just Validate come da guida.
È possibile testare la validazione del campo con autocompletamento sulla pagina di esempio validazione.