Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-03-2014, 00:06   #1
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
[Jquery] Numero di input legato al valore della checknbox

Salve a tutti,
avrei bisogno di generare un numero di input pari al valore selezionato in checkbox.

Mi spiego meglio:
- ho un form in cui mostro n checkbox con valore progressivi, ad esempio da 1 a 6.
- quando l'utente seleziono una di esse (è possibile selezionarne solo una!) nel form sotto mi vengono visualizzati un numero di input pari al valore della mia checkbox.

Oppure, potrei creare a priori queste input di numero da 1 a 6 e settarle a display: none e a click mostrare solo quelle il cui valore è sempre dettato dalla checkbox.

Come potrei fare?

Grazie.

Ultima modifica di robertino_salemi : 14-03-2014 alle 00:08.
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2014, 07:41   #2
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Quando vuoi che venga selezionata al massimo una casella per volta devi usare l'oggetto "option" che gestisce nativamente questa caratteristica senza che debba essere tu ad implementarla.

Se vuoi che cambiando la selezione vengano preservati i valori dei campi già visibili ti conviene creare tutti i campi ed impostare display:none per nasconderli.
Puoi implementarla in questo modo:
1) utilizzando un opportuno selettore jQuery ottieni l'insieme dei campi
2) attraverso il metodo each vai ad analizzare ciascun campo e:
- se l'indice è minore del numero selezionato richiami sul campo il metodo show
- in caso contrario richiami il metodo hide

In alternativa puoi generare dinamicamente i campi in questo modo:
prima di tutto crea un contenitore per i tuoi campi di input ed assegnagli un id;
all'evento change dell'option associa una funzione che:
1) recupera il valore selezionato;
2) svuota il contenitore con il metodo empty;
3) attraverso un ciclo for crea i campi di input;
4) ad ogni campo associa un attributo name che contiene l'indice del ciclo, in modo che siano tutti diversi;
5) inserisce il campo creato nel contenitore con il metodo appendTo.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2014, 09:23   #3
OoZic
Senior Member
 
L'Avatar di OoZic
 
Iscritto dal: Nov 2010
Città: Londra
Messaggi: 620
http://jsfiddle.net/t6PW4/

js:
Codice:
$('.radio-number').on('change', function () {
    var n = $(this).data('number');
    for (var i = 0; i < n; i++) {
        $('#input' + n).removeClass('hidden');
    }
});
lascio a te completare la funzione per ri-aggiungere la classe hidden nel caso uno cambi selezione.

ps: se si parla di una sola scelta non si parla di checkbox ma di radio
__________________
> This is me <
When you gaze long into an abyss the abyss also gazes into you.
OoZic è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2014, 10:26   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2790
L'hanno già detto ma lo ribadisco, per favore non usare i checkbox al posto dei radio! Non uccidere l'html! A lavoro ho visto cose... che non vorrei più rivedere, neanche in un forum.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2014, 16:36   #5
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Che dire...grazie a tutti per il supporto e i consigli!

Daniels118: sei stato molto dettagliato e hai reso bene l'idea di ciò che dovrei creare.
Per fortuna so a priori qual è il valore massimo che l'utente potrà selezionare, quindi mi creo gli input che mi servono e me li setto a display:none (come da te indicato!) e successivamente li visualizzo.

OoZic: grazie per aver postato una buona parte della soluzione, vedo di fare la visualizzazione per nasconderli e postarla.
Magari al cambio del valore della checkbox faccio in modo che vengano nascosti tutti e subito dopo applico quella da te indicata.

wingman87: hai perfettamente ragione, è stato un mio errore, si tratta di radio e non checkbox.

Grazie ancora!
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2014, 09:36   #6
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Ecco la soluzione finale, funziona!

http://jsfiddle.net/t6PW4/2/
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2014, 10:14   #7
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Ti conviene non specificare "checked" nell'html, oppure forzare l'evento change al caricamento della pagina, altrimenti se si vuole scegliere la prima opzione bisogna per forza selezionarne prima un'altra e poi premere sulla prima.

PS. invece di utilizzare una classe per rendere invisibili i campi prova i metodi hide e show, ti consentono di specificare la velocità con cui far apparire/scomparire gli elementi producendo un effetto più gradevole alla vista.

Ultima modifica di Daniels118 : 15-03-2014 alle 10:16.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2014, 22:53   #8
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Ti conviene non specificare "checked" nell'html, oppure forzare l'evento change al caricamento della pagina, altrimenti se si vuole scegliere la prima opzione bisogna per forza selezionarne prima un'altra e poi premere sulla prima.
Daniels, non ho capito cosa vuoi dire...il codice postato funziona correttamente!
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2014, 07:33   #9
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Aprendo il tuo esempio la prima opzione è già selezionata ma non è presente nessun campo; cliccando su tale opzione non succede nulla. Se si vuole scegliere la prima opzione, per rendere visibile il campo bisogna prima selezionare la seconda e poi ripremere sulla prima.

Così invece si può premere subito sulla prima opzione e vedere il campo:
http://jsfiddle.net/t6PW4/4/

Oppure in quest altro modo vengono visualizzati subito i campi associati all'opzione selezionata:
http://jsfiddle.net/t6PW4/5/
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2014, 10:11   #10
robertino_salemi
Senior Member
 
L'Avatar di robertino_salemi
 
Iscritto dal: Apr 2009
Città: Aci Catena (CT)
Messaggi: 1021
Grazie Daniels, ottima consiglio, non avevo prestato attenzione a questo problema.

Grazie!
robertino_salemi è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
Samsung Galaxy S27 Pro: sarà lui ...
Così Google ha ottimizzato Chrome...
Xiaomi non cambia idea: il display poste...
LG presenta in Italia le gamme TV Micro ...
Sette anni dopo l'annuncio, The Wolf Amo...
'Non avrete aumenti': la decisione shock...
TIM lancia il Pass Mondiali DAZN: 104 pa...
Tesla Roadster, promessa o miraggio? La ...
Mark Hamilton, la tavola periodica del m...
Hanger 13 annuncia Uomo d'Onore: espansi...
La battaglia delle HBM4 entra nel vivo: ...
Dopo 12 anni torna Alien: Isolation. Ecc...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 21:45.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v