Hallo und einen schönen guten Abend,
ich arbeite in meiner Freizeit für eine Bekannte an einer Website. Diese Website soll eine Kontaktseite haben, auf der die Besucher eine Buchungsanfrage stellen können. Bis jetzt nicht allzu schwer. Ich habe natürlich in der Auswertungsdatei eine Kontrolle, ob alle Pflichtfelder gefüllt worden sind. Da man dafür aber ja erst weitergeleitet werden muss, habe ich mir schon für vorher eine Lösung in Javascript zusammengebastelt. Da ich natürlich, wenn ein Feld leer ist, die Standardaktion des Browsers abbrechen muss, arbeite ich da mit "return". Ich rufe meine Funktion mit "return check()" auf und gebe dann innerhalb der Funktion mit "return false" dem Browser bekannt, dass er seine Standardaktion unterdrücken soll.
Nur tut er das nicht. Egal welchen Browser ich benutze, man wird immer auf die nächste Seite weitergeleitet. Mein Script funktioniert im Dreamweaver, der ja den Links generell nicht folgt, aber problemlos.
Hier mein HTML:
und hier mein Javascript dazu:
Ich wäre euch sehr dankbar, wenn Ihr mir da helfen könntet
Einen schönen Abend noch !
ich arbeite in meiner Freizeit für eine Bekannte an einer Website. Diese Website soll eine Kontaktseite haben, auf der die Besucher eine Buchungsanfrage stellen können. Bis jetzt nicht allzu schwer. Ich habe natürlich in der Auswertungsdatei eine Kontrolle, ob alle Pflichtfelder gefüllt worden sind. Da man dafür aber ja erst weitergeleitet werden muss, habe ich mir schon für vorher eine Lösung in Javascript zusammengebastelt. Da ich natürlich, wenn ein Feld leer ist, die Standardaktion des Browsers abbrechen muss, arbeite ich da mit "return". Ich rufe meine Funktion mit "return check()" auf und gebe dann innerhalb der Funktion mit "return false" dem Browser bekannt, dass er seine Standardaktion unterdrücken soll.
Nur tut er das nicht. Egal welchen Browser ich benutze, man wird immer auf die nächste Seite weitergeleitet. Mein Script funktioniert im Dreamweaver, der ja den Links generell nicht folgt, aber problemlos.
Hier mein HTML:
HTML:
<form method="post" action="auswertung.php" name="testform">
<fieldset><legend>Buchungsanfrage senden</legend>
<label for="name">Name:</label>
<input type="text" id="name" name="name" class="text">
<label for="vorname">Vorname:</label>
<input type="text" id="vorname" name="vorname" class="text">
<label for="mail">E-Mail:</label>
<input type="email" id="mail" name="mail" class="text">
<p>Buchungszeitraum:</p>
<label for="ankunft">Ankunft:</label>
<input type="date" id="ankunft" name="ankunft" class="text">
<label for="abfahrt">Abfahrt:</label>
<input type="date" id="abfahrt" name="abfahrt" class="text">
<p>Mitteilung: (optional)</p>
<textarea id="nachricht"></textarea>
</fieldset>
<fieldset style="margin-top:20px;"><legend>Telefonservice</legend>
<label for="telefon">Telefonnummer: (optional)</label>
<input type="tel" id="telefon" name="telefon" class="text">
</fieldset>
<input type="submit" id="submit" value="Senden" onsubmit="return check();">
</form>
Code:
var skip = false;
var ausnahmen = new Array("telefon", "nachricht");
function check() {
var a = document.forms[0].length;
for(i=document.forms[0].length-1; i>=0; i--) {
a = (document.forms[0].elements[i].type == "submit") ? a-1 : a;
}
for(i=a-1; i >= 0; i--) {
for(b=0; b < ausnahmen.length; b++) {
if(document.forms[0].elements[i].id == ausnahmen[b]) {
skip = true;
}
}
if(skip == false && document.forms[0].elements[i].value.length == 0) {
return false;
document.forms[0].elements[i].focus();
document.forms[0].elements[i].style.border = "1px solid red";
} else {
skip = false;
continue;
}
}
}
Ich wäre euch sehr dankbar, wenn Ihr mir da helfen könntet
Einen schönen Abend noch !