Input Numerico
Campi input con pulsanti per incrementare/decrementare valori numerici.
L’input di tipo numerico va racchiuso in uno <span>
con classe .input-number
.
Tale input emetterà l’evento change
anche all’incremento/decremento tramite i pulsanti di step.
L’attributo value=""
deve contenere un valore di default.
Esempi
La label va posizionata prima del wrapper e, per garantire l’accessibilità del campo, dovrà avere un attributo for=""
corrispondente al nome e id del campo input.
La larghezza del campo predefinita è quella del suo contenitore, per limitare la larghezza alle dimensioni del valore contenuto utilizzare il ridimensionamento adattivo.
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
<div class="w-100">
<div class="form-group">
<label for="inputNumber" class="input-number-label active">Input Number inserito in una colonna a tutta larghezza</label>
<div class="input-group input-number">
<input type="number" class="form-control" data-bs-input id="inputNumber" name="inputNumber" value="100" step="any" />
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta valore</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci valore</span>
</button>
</span>
</div>
</div>
</div>
<div class="w-50 mt-5">
<div class="form-group">
<label for="inputNumber1" class="input-number-label active">Input Number inserito in una colonna di larghezza 50%</label>
<div class="input-group input-number">
<input type="number" class="form-control" data-bs-input id="inputNumber1" name="inputNumber1" value="100" step="any" />
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta valore</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci valore</span>
</button>
</span>
</div>
</div>
</div>
Limiti e Step
Aggiungendo gli attributi HTML min=""
, max=""
e step=""
all’input è possibile limitare il valore minimo e massimo del campo e decidere di quanto varierà a ogni click sui pulsanti.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<div>
<div class="form-group">
<label for="inputNumber2" class="input-number-label active">Min, Max & Step</label>
<div class="input-group input-number">
<input type="number" class="form-control" data-bs-input id="inputNumber2" name="inputNumber2" value="100" min="-2000" max="15000" step="500" />
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta valore</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci valore</span>
</button>
</span>
</div>
</div>
</div>
Valuta
Per anteporre il simbolo della valuta in Euro, aggiungere la classe .input-number-currency
al wrapper .input-number
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<div>
<div class="form-group">
<label for="inputNumber3" class="input-number-label active">Currency</label>
<div class="input-group input-number input-number-currency">
<span class="input-group-text fw-semibold">€</span>
<input type="number" class="form-control" data-bs-input id="inputNumber3" name="inputNumber3" step="any" value="3.50" min="0" />
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta valore Euro</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci valore Euro</span>
</button>
</span>
</div>
</div>
</div>
Percentuale
Per anteporre il simbolo percentuale, aggiungere la classe .input-number-percentage
al wrapper .input-number
.
Si consiglia di impostare gli attributi min=0
e max="100"
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<div>
<div class="form-group">
<label for="inputNumber4" class="input-number-label active">Percentage</label>
<div class="input-group input-number input-number-percentage">
<span class="input-group-text fw-semibold">%</span>
<input type="number" class="form-control" data-bs-input id="inputNumber4" name="inputNumber4" value="50" min="0" max="100" step="any" />
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta del 10%</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci del 10%</span>
</button>
</span>
</div>
</div>
</div>
Disabilitato
Per disabilitare un Input number, aggiungere la classe .disabled
al wrapper .input-number
.
Aggiungere anche l’attributo disabled
al campo e ai pulsanti.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<div>
<div class="form-group">
<label for="inputNumber5" class="input-number-label active">Disabled</label>
<div class="input-group input-number disabled">
<input type="number" class="form-control" data-bs-input id="inputNumber5" name="inputNumber5" value="50" min="0" max="100" step="1" disabled />
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta valore</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci valore</span>
</button>
</span>
</div>
</div>
</div>
Ridimensionamento
È possibile far sì che il campo numerico si ridimensioni automaticamente a
seconda del valore contenuto in esso. Per ottenere questo comportamento, è
sufficiente aggiungere la classe input-number-adaptive
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<div class="w-100">
<div class="form-group">
<label for="inputNumber6" class="input-number-label active">Adattivo</label>
<div class="input-group input-number input-number-adaptive">
<input type="number" class="form-control" data-bs-input id="inputNumber6" name="inputNumber6" value="99999" step="any">
<span class="input-group-text align-buttons flex-column">
<button class="input-number-add">
<span class="visually-hidden">Aumenta valore</span>
</button>
<button class="input-number-sub">
<span class="visually-hidden">Diminuisci valore</span>
</button>
</span>
</div>
</div>
</div>
Attivazione tramite JavaScript
È possibile creare un’istanza con il constructor, ad esempio:
1
2
var inputElement = document.getElementById('inputNumber6')
var inputNumber = new bootstrap.InputNumber(inputElement)