qmaestroq Geschrieben 31. März 2003 Geschrieben 31. März 2003 Hallo Leute, ich habe mit php ein Formular genastelt, in der ich eine dynamische Anzahl von Checkboxen anzeigen lasse. Diese Checkboxen werden dynamisch mit einem Zähler durchnummeriert, also checkid[1], checkid[2] usw. Nun möchte ich einen Button haben, der automatisch alle Checkboxen anhakt. Ich habe dazu schon ein Script gefunden, aber leider weiss ich nicht, warum das nicht geht, das Formular heißt "eintragen": echo" <SCRIPT LANGUAGE=\"JavaScript\"> <!-- var checkflag = \"false\"; function check(checkid) { if (checkflag == \"false\") { for (i = 1; i < field.length; i++) { document.eintragen.checkid.checked = true;} checkflag = \"true\"; return \"alle entmarkieren\"; } else { for (i = 1; i < field.length; i++) { document.eintragen.checkid.checked = false; } checkflag = \"false\"; return \"alle markieren\"; } } // --> </SCRIPT>"; So, nun rufe ich das so auf: echo"<td><center><input type=button value=\"alle markieren\" onClick=\"this.value=check(this.form.checkid)\"></center></td>"; Aber leider tut sich da überhaupt nichts :-( Wer weiß vielleicht warum? Danke im voraus... Gruß maestro
sYnTaxx Geschrieben 31. März 2003 Geschrieben 31. März 2003 Originally posted by qmaestroq echo"<td><center><input type=button value=\"alle markieren\" onClick=\"this.value=check(this.form.checkid)\"></center></td>"; Also der obere Teil scheint mir zu funktionieren es muss was mit dem Aufrufe zu tun haben... Schonmal sowas probiert: echo"<td><center><input type=button value=\"alle markieren\" onClick=\"check(this.form.checkid)\"></center></td>"; oder echo"<td><center><input type=button value=\"alle markieren\" onClick=\"check(this.checkid)\"></center></td>"; Sind leider von mir nur Denkansätze aber mehr kann ich leider nicht liefern. Dürfte wirklich an dem Aufruf liegen...
qmaestroq Geschrieben 31. März 2003 Autor Geschrieben 31. März 2003 Hmm, hat leider nicht geklappt, ich schätze aber auch, dass das am Aufruf liegt :-( Aber danke trotzdem...
loeti Geschrieben 31. März 2003 Geschrieben 31. März 2003 Originally posted by qmaestroq Diese Checkboxen werden dynamisch mit einem Zähler durchnummeriert, also checkid[1], checkid[2] usw. d.h. du behandelst die Checkboxen wie ein Array? Oder verstehe ich hier was falsch? Normalerweise sieht der HTML Code doch folgendermaßen aus: <form name="myform" action="..."> <input type="checkbox" name="checkbox1" value="...">... <input type="checkbox" name="checkbox2" value="...">... <input type="checkbox" name="checkbox3" value="...">... <input type="submit" value="alle markieren"> </form> Wenn du dann die Checkboxen alle markieren möchtest, musst du im JavaScript Teil folgendermaßen vorgehen: function checkAll () { for (var i=0; i<anzahl; i++) { // "anzahl" ersetzt du durch die Anzahl der Checkboxen, die kennst du ja beim Aufbau des HTML Codes eval("document.myform.checkbox" + i + ".checked = true;"); } } Der Code ist ungetestet, sollte aber so laufen.
Spike Geschrieben 1. April 2003 Geschrieben 1. April 2003 Mit einer for-Schleife kannst du alle Formularelemente durchgehen, mit der type-Eigenschaft kannst du Abragen, ob es sich um eine Checkbox handelt und mit der checked-Eigenschaft kannst du die Checkbox ankreuzen. for (i=0; i<document.formularname.elements.length; i++) if (document.formularname.elements[i].type == "checkbox") document.formularname.elements[i].checked = true;
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden