|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
[Javascript] Lavorare sulle checkbox
Ciao
Allora, ho una form con una serie di checkbox. Queste checkbox sono legate a variabili che fanno parte di un albero, ed io vorrei che se cliccassi su una mi si cliccassero automaticamente anche tutte quelle legate ai "figli". In soldoni, ogni checkbox ha un nome del tipo (dove i nomi che vedete corrispondono alle etichette dei nodi dell'albero... Quindi Pippo_Topolino e Pippo_Topolino_Pluto si trovano sullo stesso ramo, ma la seconda ha un nodo in più): 1) Pippo_Topolino 2) Pippo_Topolino_Pluto 3) Pippo_Topolino_Pluto_Paperino Se clicco sulla seconda, si deve cliccare anche la terza (Paperino è un figlio di Pluto) Se clicco sulla prima si devono cliccare anche le altre due (Pluto è un figlio di Topolino, e Paperino è un figlio di Pluto) Spero di non essere stato troppo contorto... Mi sto spulciando la guida su html.it , ma se nel frattempo qualcuno riesce a darmi delle dritte (sono assolutamente a zero di javascript, ma conosco il java) glie ne sarei molto grato "Ci sono tante cose da fare, e così poco tempo...." |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2125
|
fai un evento onClick che richiama una funzione che si preoccupa di checkare anche gli altri.
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale. Go to a Wormhole |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Prova questa pagina e dimmi se è quello che volevi:
Codice:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>Prova selezione checkbox</title>
<script type="text/javascript">
<!--
function click_chkbox (chk)
{
var len = chk.name.length;
var elements = document.form1.elements;
for (var i = 0; i < elements.length; i++)
{
if (elements[i].name.substr (0, len) == chk.name)
elements[i].checked = chk.checked;
}
}
//-->
</script>
</head>
<body>
<form name="form1">
<input type="checkbox" onclick="click_chkbox(this)" name="uno">Checkbox 1
<br>
<input type="checkbox" onclick="click_chkbox(this)" name="uno_due">Checkbox 2
<br>
<input type="checkbox" onclick="click_chkbox(this)" name="uno_due_tre">Checkbox 3
<br>
<input type="checkbox" onclick="click_chkbox(this)" name="uno_due_tre_quattro">Checkbox 4
<br>
</form>
</body>
</html>
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
|
#4 | |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
Quote:
|
|
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Quote:
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
Quote:
Non chiedermi il perchè... non ne ho la più pallida idea.... Lo avevo provato su ie e firefox, e non andava da nessuna delle due parti E' quasi quello che mi serve (ma non è colpa tua, sono stato io poco chiato). In realtà è possibile avere due checkbox: Pippo_Topolino_Pluto Pippo_Topolino_Pluto1 Con il tuo codice se clicco la prima clicca pure la seconda, ma in realtà Pluto e Pluto1 sono nodi diversi, quindi non lo dovrebbe fare. Ora vedo se riesco a modificare il codice, intanto grazie Ultima modifica di Edde : 02-02-2007 alle 16:40. |
|
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Quote:
Prova con questa funzione: Codice:
function click_chkbox (chk)
{
var len = chk.name.length;
var elements = document.form1.elements;
var regex = new RegExp ("^\\d+$");
for (var i = 0; i < elements.length; i++)
{
var elem_name = elements[i].name;
if (elem_name.substr (0, len) == chk.name && !regex.test (elem_name.substr (len)))
elements[i].checked = chk.checked;
}
}
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
Non capisco... ho inserito il tuo codice in una jsp e mi da l'errore di prima...
Ti posto la pagina che ne viene fuori: http://otakar.altervista.org/Varie/E...Properties.htm |
|
|
|
|
|
#9 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Quote:
Hai messo: <form action="Start" method="POST" > Comunque prova il codice che ho postato appena prima ... dovrebbe risolvere la questione del numero finale.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
|
|
#10 | |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
Quote:
"uno" "uno_due" "uno_due_tre" "uno_due_tre1" "uno_due_tre_quattro" Cliccando sulla prima non mi clicca la terza (mentre in realtà dovrebbe farlo). Ho risolto così: Codice:
function click_chkbox (chk)
{
varr len = chk.name.length;
var elements = document.form1.elements;
for (var i = 0; i < elements.length; i++)
{
if (elements[i].name.substr (0, len+1) == chk.name+"_")
elements[i].checked = chk.checked;
}
}
|
|
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
Quote:
|
|
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
|
C'era anche un altro errore (colpa mia).
Ti voglio bene Grazie ancora |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 09:31.



















