Ammeres: JS - Variablen in HTML mehrfach belegen, mit einer Funktion auswerten

Beitrag lesen

Hallo,

Hintergrund: Ich möchte ein Formular erstellen, das dem Nutzer ähnlich einer MindMap durch einen Pfad führt, abhängig von seinen bisherigen Eingaben. Ausgehend vom Hauptknoten gibt es jeweils mehrere Fieldsets, die anfangs "hidden" sind und über eine Wenn-Dann-Funktion für den Nutzer sichtbar werden sollen.

Kurz gesagt: Ich möchte mit JS das Attribut "hidden" hinzufügen oder entfernen können.

Gedanke: Theoretisch sollte dafür EIN JavaScript genügen, das immer wieder verwendet wird - vorausgesetzt, ich belege dieselben Variablen im entsprechenden Fieldset mit jeweils anderen Werten.

JS-DATEI:

function Sichtbarkeit() {
if (WertIst == WertSoll)
document.getElementByClass("EinAusblenden").removeAttribute "hidden"
else
document.getElementByClass("EinAusblenden").setAttribute "hidden"
}

Entsprechent wird in jedem Fieldset ein Script eingebunden, das die jeweilige Variable deklariert.

HTML-DATEI:

<fieldset name="..." class="EinAusblenden">
<script>
let WertIst = document.getElementById("vorherigeAuswahl").value
let WertSoll = "RichtigeAuswahlFürDiesesFieldset"
</script>

[nächste Auswahlmöglichkeiten]
</fieldset>

Die Lösung sollte möglich sein und ist sicher deutlich eleganter, als für jedes Fieldset ein eigenes Script mit geringen Abweichungen zu definieren. Leider bin ich zu doof, das auch praktisch umzusetzen. Möglich, dass ich irgendwo einen dummen Anfängerfehler mache und was übersehe.

Alternativ könnte ich auch im HTML direkt zu "true" oder "false" auswerten und im JS nur noch den Attributswechsel verarbeiten. Das kann praktisch sein, wenn mehrere Auswahlmöglichkeiten richtig sind, erfordert aber wieder mehr Code im HTML-Dokument.

Hat irgend jemand Vorschläge?

akzeptierte Antworten