Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Checkboxen dynamisch

Empfohlene Antworten

Veröffentlicht

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

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...

Hmm, hat leider nicht geklappt, ich schätze aber auch, dass das am Aufruf liegt :-(

Aber danke trotzdem...

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.

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;

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.